java中文傳值亂碼問題的解決方法
本文實(shí)例為大家分享了java中文傳值亂碼問題,以及解決方法,供大家參考,具體內(nèi)容如下
一般編碼格式設(shè)置:
1.可以經(jīng)過兩次編碼處理,即設(shè)置字符集后,在插入前解碼字符集,也是最有效的方式
設(shè)置字符集:
String value=null;
try {
value= URLEncoder.encode(jsonObjectPar.getString(“value”), “UTF-8”);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
解碼字符集:
String value=null;
try {
value= new String(value.getBytes(“iso-8859-1”),”UTF-8”);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
2.直接處理:
userName = new String(userName.getBytes(“ISO-8859-1”), “UTF-8”);
3.如果斷點(diǎn)跟的時(shí)候插入的時(shí)候是中文,到數(shù)據(jù)庫后亂碼,一般是數(shù)據(jù)庫沒有設(shè)置為UTF-8;
首先查看數(shù)據(jù)庫編碼(MySQL為例):
數(shù)據(jù)庫查詢中運(yùn)行: show variables like ‘character%';查看所有編碼信息
修改不是UTF-8的字符集,主要查看datebase是否是UTF-8, 命令
show variables like ‘character%'; +————————–+—————————-+ | Variable_name | Value | +————————–+—————————-+ | character_set_client | latin1 | | character_set_connection | latin1 | | character_set_database | latin1 | | character_set_filesystem | binary | | character_set_results | latin1 | | character_set_server | latin1 | | character_set_system | utf8 | | character_sets_dir | /usr/share/mysql/charsets/ | +————————–+—————————-+
從以上信息可知數(shù)據(jù)庫的編碼為latin1,需要修改為gbk或者是utf8;
其中,character_set_client為客戶端編碼方式;character_set_connection為建立連接使用的編碼;character_set_database數(shù)據(jù)庫的編碼; character_set_results結(jié)果集的編碼; character_set_server數(shù)據(jù)庫服務(wù)器的編碼,只要保證以上四個(gè)采用的編碼方式一樣,就不會(huì)出現(xiàn)亂碼問題。
4.從后臺(tái)到頁面亂碼的問題:
返回?cái)?shù)據(jù)之前先設(shè)置字符集:
response.setCharacterEncoding(“utf-8”);
5.jsp頁面到后臺(tái)亂碼:
5-1.jsp的編碼設(shè)置為utf-8
5-2.后臺(tái)這樣判斷
String name = request.getParameter(“ABC”);
if(name.equals(new String(request.getParameter(“ABC”).getBytes(“iso8859-1”), “iso8859-1”))) {
name = new String(name.getBytes(“iso8859-1”),”UTF-8”);
}
get方式提交的編碼是iso8859-1
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
feign調(diào)用返回object類型轉(zhuǎn)換方式
這篇文章主要介紹了feign調(diào)用返回object類型轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06
引入SpringCloud-gateway報(bào)錯(cuò)的解決方案
這篇文章主要介紹了引入SpringCloud-gateway報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07
基于Apache組件分析對(duì)象池原理的實(shí)現(xiàn)案例分析
本文從對(duì)象池的一個(gè)簡(jiǎn)單案例切入,主要分析common-pool2組件關(guān)于:池、工廠、配置、對(duì)象管理幾個(gè)角色的源碼邏輯,并且參考其在Redis中的實(shí)踐,對(duì)Apache組件分析對(duì)象池原理相關(guān)知識(shí)感興趣的朋友一起看看吧2022-04-04

