本文實例為大家分享了java中文傳值亂碼問題,以及解決方法,供大家參考,具體內(nèi)容如下
一般編碼格式設(shè)置:
1.可以經(jīng)過兩次編碼處理,即設(shè)置字符集后,在插入前解碼字符集,也是最有效的方式
設(shè)置字符集:
1
2
3
4
5
|
<span style= "color: #000000" >String value= null ; <br></span> try { value= URLEncoder.encode(jsonObjectPar.getString(“value”), “UTF- 8 ”); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } |
解碼字符集:
1
2
3
4
5
6
|
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.如果斷點跟的時候插入的時候是中文,到數(shù)據(jù)庫后亂碼,一般是數(shù)據(jù)庫沒有設(shè)置為UTF-8;
首先查看數(shù)據(jù)庫編碼(MySQL為例):
數(shù)據(jù)庫查詢中運行: show variables like ‘character%';查看所有編碼信息
修改不是UTF-8的字符集,主要查看datebase是否是UTF-8, 命令
1
2
3
4
5
6
7
8
9
10
11
12
13
|
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ù)器的編碼,只要保證以上四個采用的編碼方式一樣,就不會出現(xiàn)亂碼問題。
4.從后臺到頁面亂碼的問題:
返回數(shù)據(jù)之前先設(shè)置字符集:
response.setCharacterEncoding(“utf-8”);
5.jsp頁面到后臺亂碼:
5-1.jsp的編碼設(shè)置為utf-8
5-2.后臺這樣判斷
1
2
3
4
|
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)容,希望對大家的學習有所幫助,也希望大家多多支持服務(wù)器之家。