摘要:中對(duì)字符串使用的是中默認(rèn)的編碼省略其他代碼編碼格下,中文是亂碼的。因此我們需要將編碼格式設(shè)置為的格式才能支持中文。以上方式自己親測(cè)可用,如果使用了上述方式還是亂碼的話,可以排查下是不是后端沒(méi)有設(shè)置編碼格式
RestTemplate中對(duì)字符串使用的是StringHttpMessageConverter中默認(rèn)的編碼
public class StringHttpMessageConverter extends AbstractHttpMessageConverter{ //省略其他代碼 public static final Charset DEFAULT_CHARSET = StandardCharsets.ISO_8859_1; }
ISO_8859_1編碼格下,中文是亂碼的。因此我們需要將編碼格式設(shè)置為UTF-8的格式才能支持中文。
網(wǎng)絡(luò)上大部分的教程都是通過(guò)以下方式來(lái)修改編碼格式
RestTemplate restTemplate = new RestTemplate(); restTemplate.getMessageConverters().set(1, new StringHttpMessageConverter(StandardCharsets.UTF_8));
原因是在RestTemplate的構(gòu)造函數(shù)中,對(duì)messageConverters賦值時(shí),在下標(biāo)為1的位置設(shè)置的是StringHttpMessageConverter對(duì)象。
public class RestTemplate extends InterceptingHttpAccessor implements RestOperations { public RestTemplate() { this.messageConverters.add(new ByteArrayHttpMessageConverter()); this.messageConverters.add(new StringHttpMessageConverter());//此處設(shè)置 this.messageConverters.add(new ResourceHttpMessageConverter(false)); //省略其他代碼 } }
但是這種寫(xiě)死下標(biāo)的方式是極為不推薦的,因?yàn)椴慌懦齋pring在后續(xù)版本中因?yàn)橐肓似渌D(zhuǎn)換器而導(dǎo)致下標(biāo)變化的問(wèn)題。推薦使用以下方式。
public static void setRestTemplateEncode(RestTemplate restTemplate) { if (null == restTemplate || ObjectUtils.isEmpty(restTemplate.getMessageConverters())) { return; } List> messageConverters = restTemplate.getMessageConverters(); for (int i = 0; i < messageConverters.size(); i++) { HttpMessageConverter> httpMessageConverter = messageConverters.get(i); if (httpMessageConverter.getClass().equals(StringHttpMessageConverter.class)) { messageConverters.set(i, new StringHttpMessageConverter(StandardCharsets.UTF_8)); } } }
我們新增一個(gè)方法,將RestTemplate對(duì)象傳遞進(jìn)去,內(nèi)部遍歷messageConverters,找到StringHttpMessageConverter并替換為UTF-8格式的StringHttpMessageConverter對(duì)象即可。
以上方式自己親測(cè)可用,如果使用了上述方式還是亂碼的話,可以排查下是不是后端沒(méi)有設(shè)置編碼格式
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/75771.html
最近在做一個(gè)SSM框架的項(xiàng)目,總是遇到一個(gè)問(wèn)題,就是后臺(tái)接收前端傳遞的中文參數(shù)的時(shí)候,參數(shù)是亂碼的,導(dǎo)致sql語(yǔ)句經(jīng)常無(wú)法執(zhí)行,但是有很奇怪,在測(cè)試環(huán)境和生產(chǎn)環(huán)境都是正常的,就是本地開(kāi)發(fā)環(huán)境總是這么坑人,那如何解決呢?1、比較累人,就是能不傳中文就不傳中文參數(shù),對(duì)于這點(diǎn),大家就笑笑而過(guò)就行了。。。。 2、還是挺累人,真的得傳中文,那就將中文強(qiáng)制轉(zhuǎn)碼了,如下: 中文.getBytes(UTF-8);...
摘要:找到文件夾下的文件添加到數(shù)據(jù)庫(kù)連接處案例完美解決亂碼 1.找到文件夾下的 app/config/service.php 文件 2.添加 ‘charset’ => ‘utf8’ 到數(shù)據(jù)庫(kù)連接處 案例: $di->set(‘db’, function() use ($config) { return new DbAdapter(array( ‘host’ => ...
閱讀 3163·2021-09-30 09:47
閱讀 2021·2021-09-22 16:04
閱讀 2289·2021-09-22 15:44
閱讀 2546·2021-08-25 09:38
閱讀 547·2019-08-26 13:23
閱讀 1233·2019-08-26 12:20
閱讀 2817·2019-08-26 11:59
閱讀 1085·2019-08-23 18:40