徹底解決Spring MVC中文亂碼問(wèn)題的方案
亂碼是讓人很頭疼的一件事,本文介紹了徹底解決Spring MVC中文亂碼問(wèn)題的方案,具體如下:
1:表單提交controller獲得中文參數(shù)后亂碼解決方案
注意: jsp頁(yè)面編碼設(shè)置為UTF-8
form表單提交方式為必須為post,get方式下面spring編碼過(guò)濾器不起效果
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <form action="${ctx}/user/addUser" name="userForm" method="post">
修改web.xml,增加編碼過(guò)濾器,如下(注意,需要設(shè)置forceEncoding參數(shù)值為true)
<filter> <filter-name>characterEncodingFilter</filter-name> <filter-class>orgspringframeworkwebfilterCharacterEncodingFilter</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>
注意:數(shù)據(jù)庫(kù)編碼是否支持中文
數(shù)據(jù)庫(kù)表和表字段是否正確
在配置連接數(shù)據(jù)庫(kù)的參數(shù)設(shè)置修改:
<property name="url" value="jdbc:mysql://localhost:3306/dbname?useUnicode=true&characterEncoding=UTF-8"></property>
第一種情況:
jsp頁(yè)面中文輸入,到controller亂碼,這時(shí)候需要設(shè)置的是在web.xml文件中添加一個(gè)編碼的過(guò)濾器(filter)將編碼統(tǒng)一為UTF-8,代碼如下:
Web.xml配置文件:
<filter> <filter-name>CharacterEncodingFilter</filter-name> <filter-class>orgspringframeworkwebfilterCharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>utf-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>CharacterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
這里需要注意的是,最好把這段代碼放在webxml中開(kāi)頭的位置,因?yàn)閿r截有順序,如果放在后面的話容易攔截不到。
第二種情況:
數(shù)據(jù)庫(kù)中文數(shù)據(jù),jsp頁(yè)面顯示亂碼(不是嚴(yán)格意義上的亂碼,而是以問(wèn)號(hào)的形式呈現(xiàn))
由于我們前后臺(tái)的數(shù)據(jù)交互使用的是json數(shù)據(jù),出現(xiàn)這種情況的原因我也不太清楚,之前也沒(méi)遇到過(guò),只能怪自己做過(guò)的項(xiàng)目太少,解決起來(lái)也不困難,只需要在轉(zhuǎn)json的時(shí)候設(shè)置一下編碼格式就可以了,代碼如下:
responsesetContentType("application/json;charset=UTF-8");//防止數(shù)據(jù)傳遞亂碼
寫(xiě)上這句話就不會(huì)再出現(xiàn)亂碼了。
第三種情況:
頁(yè)面中文,傳遞到controller也是正確的,但是保存到數(shù)據(jù)庫(kù)之后就是亂碼(也不是嚴(yán)格意義的亂碼,跟上面一樣全是問(wèn)號(hào))
這個(gè)問(wèn)題困擾了我一段時(shí)間,開(kāi)始覺(jué)得數(shù)據(jù)庫(kù)的編碼格式不正確,重新創(chuàng)建了編碼格式為utf-8的數(shù)據(jù)庫(kù)也還是不可以,最后覺(jué)得是jboss的問(wèn)題,我們的服務(wù)器用的是jboss,上網(wǎng)查了資料在連接數(shù)據(jù)源的時(shí)候加上編碼格式就可以了,代碼如下:
<datasource jta="true" jndi-name="java:jboss/datasources/JcMysqlDS" pool-name="JcMysqlDS" enabled="true" use-java-context="true"> <connection-url>jdbc:mysql://46/ITOO_BASIC_BASIC?useUnicode=true&characterEncoding=UTF-8</connection-url> <driver>mysql</driver> <pool> <prefill>false</prefill> <use-strict-min>false</use-strict-min> <flush-strategy>FailingConnectionOnly</flush-strategy> </pool> <security> <user-name>root</user-name> <pass<a href="http://wwwitnet/edu/ebg/" target="_blank" class="keylink">word</a>>123456</pass<a href="http://wwwitnet/edu/ebg/" target="_blank" class="keylink">word</a>> </security> </datasource>
1.頁(yè)面亂碼
頁(yè)面相對(duì)是最為容易解決的,往往是在相應(yīng)的jsp頁(yè)面或者h(yuǎn)tml頁(yè)面設(shè)置相關(guān)的字符集即可。如
2.傳值亂碼
在傳值過(guò)程中,也是亂碼出現(xiàn)的頻繁地。先不說(shuō)到底是什么場(chǎng)景了,通常常用的方案有如下幾個(gè)配置指定的filter
<!-- 配置請(qǐng)求過(guò)濾器,編碼格式設(shè)為UTF-8,避免中文亂碼--> <filter> <filter-name>springUtf8Encoding</filter-name> <filter-class>orgspringframeworkwebfilterCharacterEncodingFilter</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>
設(shè)置request字符集
往往從前臺(tái)傳入到對(duì)應(yīng)的controller或者是action之后出現(xiàn)亂碼,講講我一般的思路是先打印request本身默認(rèn)的字符集
Systemoutprintln(requestgetCharacterEncoding());
接著按照情況,如果打印的不是所需要的字符集則設(shè)置相應(yīng)字符集即可
requestsetCharacterEncoding("UTF-8");
當(dāng)然某種情況可能還是無(wú)法解決這時(shí)候用以下這個(gè)即可
String str=newString((requestgetParameter("bigQuestionTypeName"))getBytes("iso-8859-1"),"utf-8")
3.存入數(shù)據(jù)庫(kù)亂碼
這個(gè)相對(duì)就比較復(fù)雜,這里lz用的MySQL,且以mysql來(lái)介紹如何來(lái)解決這個(gè)亂碼問(wèn)題
大家都知道,無(wú)論是底層使用的是純粹的jdbc還是hibernate還是jpa都好,其實(shí)本質(zhì)上都是jdbc,對(duì)應(yīng)的框架只不過(guò)在相關(guān)的基礎(chǔ)上進(jìn)行特定的封裝。所以無(wú)論是什么樣的技術(shù),都會(huì)用到連接到數(shù)據(jù)庫(kù)的url。所以u(píng)rl首先是需要檢查的
url
標(biāo)準(zhǔn)情況會(huì)在相應(yīng)的后面加上相應(yīng)的字符集設(shè)置,如下
jdbcUrl=jdbc:mysql:///itcastoa?useUnicode=true&characterEncoding=UTF-8
如上,useUnicode就不用說(shuō)了,連接數(shù)據(jù)庫(kù)中設(shè)置的字符集,&這是什么的?這就有問(wèn)題了,在xml中&是&的轉(zhuǎn)義字符。如果你是用xml來(lái)配置對(duì)應(yīng)的數(shù)據(jù)庫(kù)連接配置的話就什么問(wèn)題了。但是如果用的是**properties就有問(wèn)題了,則必須將amp除去即可。這個(gè)確實(shí)是lz經(jīng)歷了頭破血流的經(jīng)驗(yàn)啊。
數(shù)據(jù)庫(kù)
這里的問(wèn)題也是相對(duì)比較難處理的,登錄數(shù)據(jù)庫(kù)
查看數(shù)據(jù)庫(kù)編碼格式
<img width="576" height="378" style="width: 630px; height: 52px; display: inline;" alt="計(jì)算機(jī)生成了可選文字:夕sql>useitcastoaatabasechanged夕sql二status夕sqlUer14。14Distribs。6。19,forUin64onnectionid:u獷獷entdatabase:LtrrentLtser:SL:singdelimiteP:e護(hù)ue護(hù)ue護(hù)sion:rotocolve獷sion:onnection:e獷uercha獷acterset:bcharacterset:lientcha護(hù)acte護(hù)set:onn。cha護(hù)acte護(hù)set:CPport:ptine:1itcastoarootelocal卜ostHotinuse;5。6。19H夕SQLCo。。unit夕Seruer1日l(shuí)ocalhostviaTCP/IPlatinlUtfsgbkgbk33日61hour51oin4?sechPeads:S:6日1Questions:7que護(hù)iesPe護(hù)second510討querie忍:日opens:" src="http://www2ctocom/uploadfile/Collfiles/20150302/png" 7plu忍htahle忍:1opentablaug:日。日日1夕sql>"="">
可以看到server的字符集還是latin1,這里就需要講一下常用的字符集了。
為了世界的和平和繁榮昌盛,ISO組織指定了一套u(yù)nicode字符集方案,Unicode編碼是不同編碼之間相互交流轉(zhuǎn)換的橋梁,包含了32位二進(jìn)制,所以能容納2的31次方的字符,有生之年是夠用了。而根據(jù)不同的需要Unicode又分為三種方案。
Utf8:用以解決國(guó)際上不同語(yǔ)言而出現(xiàn)的編碼。對(duì)英文是使用8位,中文則為3位。可以在任何支持utf9字符集的瀏覽器上顯示,無(wú)需另行處理。
另外兩種為utf16和32,這里不再編著。大家自行查閱即可,總的還是因?yàn)榇鎯?chǔ)和使用的方便來(lái)決定使用哪種。
好了,另外相對(duì)熟悉的就是gbk,俗稱(chēng)國(guó)標(biāo)碼,中國(guó)國(guó)家標(biāo)準(zhǔn)來(lái)制定,僅僅包含中文字符。所以相對(duì)兩講,utf8的兼容更好,但是存儲(chǔ)量更大。
馬上回來(lái),大致對(duì)字符集充了電還是回來(lái)先解決問(wèn)題。這里所以用gbk或者utf8都是可以的。但是latin1肯定是不可以的,這里主要通過(guò)這樣一個(gè)命令來(lái)設(shè)置
分別設(shè)置設(shè)置了服務(wù)器、數(shù)據(jù)庫(kù)和數(shù)據(jù)表部分的編碼,必須設(shè)置連接編碼。連接編碼設(shè)置如下:
mysql> SET character_set_client='gbk'; mysql> SET character_set_connection='gbk' mysql> SET character_set_results='gbk'
設(shè)置好編碼,下面便可以成功插入中文了,其實(shí)用一句話即可解決
常用命令
查看數(shù)據(jù)庫(kù)編碼格式
show variables like 'character_set_%';
查看數(shù)據(jù)庫(kù)中的表的創(chuàng)建
show create table tablename;
設(shè)置數(shù)據(jù)庫(kù)編碼格式
setnames 'gbk';
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot定時(shí)任務(wù)設(shè)計(jì)之時(shí)間輪案例原理詳解
這篇文章主要為大家介紹了SpringBoot定時(shí)任務(wù)設(shè)計(jì)之時(shí)間輪案例原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10Java Lombok簡(jiǎn)介、使用、工作原理、優(yōu)缺點(diǎn)
這篇文章主要介紹了Java Lombok簡(jiǎn)介、使用、工作原理、優(yōu)缺點(diǎn)的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用Java Lombok,感興趣的朋友可以了解下2021-03-03一篇文章帶你使用SpringBoot基于WebSocket的在線群聊實(shí)現(xiàn)
這篇文章主要介紹了一篇文章帶你使用SpringBoot基于WebSocket的在線群聊實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10Struts2中validate數(shù)據(jù)校驗(yàn)的兩種方法詳解附Struts2常用校驗(yàn)器
這篇文章主要介紹了Struts2中validate數(shù)據(jù)校驗(yàn)的兩種方法及Struts2常用校驗(yàn)器,本文介紹的非常詳細(xì),具有參考借鑒價(jià)值,感興趣的朋友一起看看吧2016-09-09詳解JAVA中implement和extends的區(qū)別
這篇文章主要介紹了詳解JAVA中implement和extends的區(qū)別的相關(guān)資料,extends是繼承接口,implement是一個(gè)類(lèi)實(shí)現(xiàn)一個(gè)接口的關(guān)鍵字,需要的朋友可以參考下2017-08-08Jmeter分布式壓力測(cè)試實(shí)現(xiàn)過(guò)程詳解
這篇文章主要介紹了Jmeter分布式壓力測(cè)試實(shí)現(xiàn)過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09解決java.util.HashMap$Values?cannot?be?cast?to?java.ut的問(wèn)題
這篇文章主要介紹了解決java.util.HashMap$Values?cannot?be?cast?to?java.ut的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03