您好,登錄后才能下訂單哦!
對于Post方式提交的數據,可以使用request.setCharacterEncoding("gb2312");來明確指定獲取請求參數時使用編碼。但是此種方式只對Post方式提交有效。
request.setCharacterEncoding("gb2312");對GET方式提交無效的原因是:該代碼只設置請求實體的編碼,而GET提交的數據是存放在請求行中的[資源名?param1="張三"¶m2=123],所以對GET請求的方式無效。
對于Get方式提交的數據,就只能手動解決亂碼:
String newName=newString(name.getBytes("ISO8859-1"),"gb2312"); String user=newString(request.getParameter("user").getBytes("ISO-8859-1"),"UTF-8");
當然,此種方法對Post方式同樣有效。
在tomcat的server.xml中可以配置http連接器的URIEncoding可以指定服務器在獲取請求參數時默認使用的編碼。
在servlet中通常會使用到如下幾個語句來解決中文亂碼問題:
request.setCharacterEncoding()是設置從request中取得的值或從數據庫中取出的值。
response.setContentType()目的是為了控制瀏覽器的行為,即控制瀏覽器用指定編碼進行解碼(指定HTTP響應的編碼,同時指定瀏覽器顯示的編碼)。
response.setCharacterEncoding()目的是用于response.getWriter()輸出的字符串的亂碼問題;如果是response.getOutputStream()是不需要此種解決方案的,因為這句話的意思是為了將response對象中的數據以UTF-8解碼后發向瀏覽器。
response.getOutputStream().write("中文".getBytes())輸出數據,這是一個字節流,寫入內存使用什么編碼,輸出就使用什么編碼。
以上就是java參數亂碼問題解決方法的詳細內容,更多請關注億速云其它相關文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。