SpringMVC中文亂碼踩坑記錄
問題
使用SpringMVC在返回一個字符串時發(fā)生了中文亂碼問題。produces
屬性無效
@RequestMapping(value = "/nihao", produces = "text/plain;charset=UTF-8") @ResponseBody public String hello(HttpServletResponse response) throws UnsupportedEncodingException { User user = new User(); user.setSex("男"); user.setName("Clover"); user.setAge(19); return user.toString(); }
HTTP/1.1 200 OK Server: Apache-Coyote/1.1 Content-Type: text/plain;charset=ISO-8859-1 Content-Length: 36 Date: Sun, 01 Aug 2021 12:20:21 GMT Connection: close { "name": "Clover", "sex": "?", "age": 19 }
添加常用的過濾器org.springframework.web.filter.CharacterEncodingFilter
依然無法解決
<filter> <filter-name>characterEncodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>utf-8</param-value> </init-param> <init-param> <param-name>forceEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>characterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
問題根源
最后查看源碼時發(fā)現(xiàn)問題出現(xiàn)在處理內(nèi)容協(xié)商的時候,SpringMVC使用了一個叫做org.springframework.http.converter.StringHttpMessageConverter
的轉(zhuǎn)換器進行處理java.lang.String
。在這個處理器中,有個一默認的編碼格式,它甚至使用了final
修飾…..
public static final Charset DEFAULT_CHARSET = Charset.forName("ISO-8859-1");
并且,通過Postman或者REST Client發(fā)送請求時,Accept
默認是*/*
。
解決方案
方案一
注冊一個StringHttpMessageConverter
,注冊之后不再使用SpringMVC默認的。它可以將produces
設(shè)置為Content-Type
。也就是說@RequestMapping
的produces
屬性生效了
<mvc:annotation-driven> <mvc:message-converters> <bean class="org.springframework.http.converter.StringHttpMessageConverter"/> </mvc:message-converters> </mvc:annotation-driven>
HTTP/1.1 200 OK Server: Apache-Coyote/1.1 Accept-Charset: ... Content-Type: text/plain;charset=utf-8 Content-Length: 37 Date: Sun, 01 Aug 2021 13:09:35 GMT Connection: close { "name": "Clover", "sex": "男", "age": 19 }
方案二
Accept問題,SpringMVC的默認StringHttpMessageConverter
處理的是*/*
,那手動設(shè)置一個Accept盡可能避開它…..
POST {{url}}/nihao HTTP/1.1 Accept: text/plain;charset=utf-8
HTTP/1.1 200 OK Server: Apache-Coyote/1.1 Content-Type: text/plain;charset=utf-8 Content-Length: 38 Date: Sun, 01 Aug 2021 13:20:16 GMT Connection: close { "name": "Clover", "sex": "男", "age": 19 }
到此這篇關(guān)于SpringMVC中文亂碼踩坑記錄的文章就介紹到這了,更多相關(guān)SpringMVC中文亂碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java 帶參數(shù)與帶返回值的方法的定義和調(diào)用
在java中,方法就是用來完成解決某件事情或?qū)崿F(xiàn)某個功能的辦法。方法實現(xiàn)的過程中,會包含很多條語句用于完成某些有意義的功能——通常是處理文本,控制輸入或計算數(shù)值,這篇文章我們來探究一下帶參數(shù)與帶返回值的方法的定義和調(diào)用2022-04-04SpringBoot使用JTA實現(xiàn)對多數(shù)據(jù)源的事務(wù)管理
了解事務(wù)的都知道,在我們?nèi)粘i_發(fā)中單單靠事務(wù)管理就可以解決絕大多數(shù)問題了,但是為啥還要提出JTA這個玩意呢,到底JTA是什么呢?他又是具體來解決啥問題的呢?本文小編就給大家介紹一下如何在Spring Boot中使用JTA實現(xiàn)對多數(shù)據(jù)源的事務(wù)管理2023-11-11spring中FactoryBean中的getObject()方法實例解析
這篇文章主要介紹了spring中FactoryBean中的getObject()方法實例解析,分享了相關(guān)代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下2018-02-02Java的四種常見線程池及Scheduled定時線程池實現(xiàn)詳解
這篇文章主要介紹了Java的四種常見線程池及Scheduled定時線程池實現(xiàn)詳解,在Java中,我們可以通過Executors類來創(chuàng)建ScheduledThreadPool,Executors類提供了幾個靜態(tài)方法來創(chuàng)建不同類型的線程池,包括ScheduledThreadPool,需要的朋友可以參考下2023-09-09Spring boot搭建web應(yīng)用集成thymeleaf模板實現(xiàn)登陸
這篇文章主要介紹了Spring boot搭建web應(yīng)用集成thymeleaf模板實現(xiàn)登陸,頁面使用bootstrap,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12Java數(shù)據(jù)結(jié)構(gòu)之棧的基本定義與實現(xiàn)方法示例
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)之棧的基本定義與實現(xiàn)方法,簡單描述了數(shù)據(jù)結(jié)構(gòu)中棧的功能、原理,并結(jié)合java實例形式分析了棧的基本定義與使用方法,需要的朋友可以參考下2017-10-10Java中的HashSet、LinkedHashSet集合解析
這篇文章主要介紹了Java中的HashSet、LinkedHashSet集合解析,與HashSet不同的是,LinkedHashSet在內(nèi)部使用了一個雙向鏈表來維護元素的順序,因此它可以保持元素的插入順序,這使得LinkedHashSet在需要保持元素順序的場景下非常有用,需要的朋友可以參考下2023-11-11