亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

徹底解決Spring MVC中文亂碼問題的方案

 更新時間:2016年11月19日 15:36:50   作者:passport_daizi  
這篇文章主要介紹了徹底解決Spring MVC中文亂碼問題的方案,具有一定的參考價值,感興趣的小伙伴們可以參考一下。

亂碼是讓人很頭疼的一件事,本文介紹了徹底解決Spring MVC中文亂碼問題的方案,具體如下:

 1:表單提交controller獲得中文參數(shù)后亂碼解決方案

注意:  jsp頁面編碼設(shè)置為UTF-8

form表單提交方式為必須為post,get方式下面spring編碼過濾器不起效果

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<form action="${ctx}/user/addUser" name="userForm" method="post">

修改web.xml,增加編碼過濾器,如下(注意,需要設(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ù)庫編碼是否支持中文

數(shù)據(jù)庫表和表字段是否正確

在配置連接數(shù)據(jù)庫的參數(shù)設(shè)置修改:

 <property name="url" value="jdbc:mysql://localhost:3306/dbname?useUnicode=true&characterEncoding=UTF-8"></property>

第一種情況:

jsp頁面中文輸入,到controller亂碼,這時候需要設(shè)置的是在web.xml文件中添加一個編碼的過濾器(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中開頭的位置,因為攔截有順序,如果放在后面的話容易攔截不到。

第二種情況:

數(shù)據(jù)庫中文數(shù)據(jù),jsp頁面顯示亂碼(不是嚴(yán)格意義上的亂碼,而是以問號的形式呈現(xiàn))

由于我們前后臺的數(shù)據(jù)交互使用的是json數(shù)據(jù),出現(xiàn)這種情況的原因我也不太清楚,之前也沒遇到過,只能怪自己做過的項目太少,解決起來也不困難,只需要在轉(zhuǎn)json的時候設(shè)置一下編碼格式就可以了,代碼如下:

responsesetContentType("application/json;charset=UTF-8");//防止數(shù)據(jù)傳遞亂碼

寫上這句話就不會再出現(xiàn)亂碼了。

 第三種情況:

頁面中文,傳遞到controller也是正確的,但是保存到數(shù)據(jù)庫之后就是亂碼(也不是嚴(yán)格意義的亂碼,跟上面一樣全是問號)

這個問題困擾了我一段時間,開始覺得數(shù)據(jù)庫的編碼格式不正確,重新創(chuàng)建了編碼格式為utf-8的數(shù)據(jù)庫也還是不可以,最后覺得是jboss的問題,我們的服務(wù)器用的是jboss,上網(wǎng)查了資料在連接數(shù)據(jù)源的時候加上編碼格式就可以了,代碼如下:

<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īng)的jsp頁面或者h(yuǎn)tml頁面設(shè)置相關(guān)的字符集即可。如

2.傳值亂碼

在傳值過程中,也是亂碼出現(xiàn)的頻繁地。先不說到底是什么場景了,通常常用的方案有如下幾個配置指定的filter

<!-- 配置請求過濾器,編碼格式設(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字符集

 往往從前臺傳入到對應(yīng)的controller或者是action之后出現(xiàn)亂碼,講講我一般的思路是先打印request本身默認(rèn)的字符集

Systemoutprintln(requestgetCharacterEncoding());

接著按照情況,如果打印的不是所需要的字符集則設(shè)置相應(yīng)字符集即可

requestsetCharacterEncoding("UTF-8");

當(dāng)然某種情況可能還是無法解決這時候用以下這個即可

String str=newString((requestgetParameter("bigQuestionTypeName"))getBytes("iso-8859-1"),"utf-8")

3.存入數(shù)據(jù)庫亂碼

這個相對就比較復(fù)雜,這里lz用的MySQL,且以mysql來介紹如何來解決這個亂碼問題

大家都知道,無論是底層使用的是純粹的jdbc還是hibernate還是jpa都好,其實本質(zhì)上都是jdbc,對應(yīng)的框架只不過在相關(guān)的基礎(chǔ)上進(jìn)行特定的封裝。所以無論是什么樣的技術(shù),都會用到連接到數(shù)據(jù)庫的url。所以url首先是需要檢查的

url

標(biāo)準(zhǔn)情況會在相應(yīng)的后面加上相應(yīng)的字符集設(shè)置,如下

 jdbcUrl=jdbc:mysql:///itcastoa?useUnicode=true&characterEncoding=UTF-8

如上,useUnicode就不用說了,連接數(shù)據(jù)庫中設(shè)置的字符集,&amp這是什么的?這就有問題了,在xml中&amp是&的轉(zhuǎn)義字符。如果你是用xml來配置對應(yīng)的數(shù)據(jù)庫連接配置的話就什么問題了。但是如果用的是**properties就有問題了,則必須將amp除去即可。這個確實是lz經(jīng)歷了頭破血流的經(jīng)驗啊。

數(shù)據(jù)庫

這里的問題也是相對比較難處理的,登錄數(shù)據(jù)庫

查看數(shù)據(jù)庫編碼格式

<img width="576" height="378" style="width: 630px; height: 52px; display: inline;" alt="計算機(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日localhostviaTCP/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:用以解決國際上不同語言而出現(xiàn)的編碼。對英文是使用8位,中文則為3位??梢栽谌魏沃С謚tf9字符集的瀏覽器上顯示,無需另行處理。

另外兩種為utf16和32,這里不再編著。大家自行查閱即可,總的還是因為存儲和使用的方便來決定使用哪種。

好了,另外相對熟悉的就是gbk,俗稱國標(biāo)碼,中國國家標(biāo)準(zhǔn)來制定,僅僅包含中文字符。所以相對兩講,utf8的兼容更好,但是存儲量更大。

馬上回來,大致對字符集充了電還是回來先解決問題。這里所以用gbk或者utf8都是可以的。但是latin1肯定是不可以的,這里主要通過這樣一個命令來設(shè)置

分別設(shè)置設(shè)置了服務(wù)器、數(shù)據(jù)庫和數(shù)據(jù)表部分的編碼,必須設(shè)置連接編碼。連接編碼設(shè)置如下:

mysql> SET character_set_client='gbk';

mysql> SET character_set_connection='gbk'

mysql> SET character_set_results='gbk'

設(shè)置好編碼,下面便可以成功插入中文了,其實用一句話即可解決

常用命令

查看數(shù)據(jù)庫編碼格式

show variables like 'character_set_%';

查看數(shù)據(jù)庫中的表的創(chuàng)建

show create table tablename;

設(shè)置數(shù)據(jù)庫編碼格式

setnames 'gbk';

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringBoot定時任務(wù)設(shè)計之時間輪案例原理詳解

    SpringBoot定時任務(wù)設(shè)計之時間輪案例原理詳解

    這篇文章主要為大家介紹了SpringBoot定時任務(wù)設(shè)計之時間輪案例原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • Java Lombok簡介、使用、工作原理、優(yōu)缺點

    Java Lombok簡介、使用、工作原理、優(yōu)缺點

    這篇文章主要介紹了Java Lombok簡介、使用、工作原理、優(yōu)缺點的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用Java Lombok,感興趣的朋友可以了解下
    2021-03-03
  • 一篇文章帶你使用SpringBoot基于WebSocket的在線群聊實現(xiàn)

    一篇文章帶你使用SpringBoot基于WebSocket的在線群聊實現(xiàn)

    這篇文章主要介紹了一篇文章帶你使用SpringBoot基于WebSocket的在線群聊實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • SpringBoot熱部署配置方法詳解

    SpringBoot熱部署配置方法詳解

    在實際開發(fā)中,每次修改代碼就需要重啟項目,重新部署,對于一個后端開發(fā)者來說,重啟確實很難受。在java開發(fā)領(lǐng)域,熱部署一直是一個難以解決的問題,目前java虛擬機(jī)只能實現(xiàn)方法體的熱部署,對于整個類的結(jié)構(gòu)修改,仍然需要重啟項目
    2022-11-11
  • Struts2中validate數(shù)據(jù)校驗的兩種方法詳解附Struts2常用校驗器

    Struts2中validate數(shù)據(jù)校驗的兩種方法詳解附Struts2常用校驗器

    這篇文章主要介紹了Struts2中validate數(shù)據(jù)校驗的兩種方法及Struts2常用校驗器,本文介紹的非常詳細(xì),具有參考借鑒價值,感興趣的朋友一起看看吧
    2016-09-09
  • 詳解JAVA中implement和extends的區(qū)別

    詳解JAVA中implement和extends的區(qū)別

    這篇文章主要介紹了詳解JAVA中implement和extends的區(qū)別的相關(guān)資料,extends是繼承接口,implement是一個類實現(xiàn)一個接口的關(guān)鍵字,需要的朋友可以參考下
    2017-08-08
  • dom4j讀取XML文件詳解

    dom4j讀取XML文件詳解

    這篇文章主要為大家詳細(xì)介紹了dom4j讀取XML文件的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Jmeter分布式壓力測試實現(xiàn)過程詳解

    Jmeter分布式壓力測試實現(xiàn)過程詳解

    這篇文章主要介紹了Jmeter分布式壓力測試實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-09-09
  • 解決java.util.HashMap$Values?cannot?be?cast?to?java.ut的問題

    解決java.util.HashMap$Values?cannot?be?cast?to?java.ut的問題

    這篇文章主要介紹了解決java.util.HashMap$Values?cannot?be?cast?to?java.ut的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • JAVA自定義注解詳情

    JAVA自定義注解詳情

    這篇文章主要介紹了Java自定義注解,結(jié)合實例形式總結(jié)分析了java常見的自定義注解類型、功能、用法及操作注意事項,需要的朋友可以參考下
    2021-10-10

最新評論