本文實例為大家分享了java中文傳值亂碼問題,以及解決方法,供大家參考,具體內容如下
一般編碼格式設置:
1.可以經過兩次編碼處理,即設置字符集後,在插入前解碼字符集,也是最有效的方式
設置字符集:
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.如果斷點跟的時候插入的時候是中文,到數據庫後亂碼,一般是數據庫沒有設置為UTF-8;
首先查看數據庫編碼(MySQL為例):
數據庫查詢中運行: 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/ | +――――――――+―――――――――-+
從以上信息可知數據庫的編碼為latin1,需要修改為gbk或者是utf8;
其中,character_set_client為客戶端編碼方式;character_set_connection為建立連接使用的編碼;character_set_database數據庫的編碼; character_set_results結果集的編碼; character_set_server數據庫服務器的編碼,只要保證以上四個採用的編碼方式一樣,就不會出現亂碼問題。
4.從後台到頁面亂碼的問題:
返回數據之前先設置字符集:
response.setCharacterEncoding(“utf-8”);
5.jsp頁面到後台亂碼:
5-1.jsp的編碼設置為utf-8
5-2.後台這樣判斷
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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。