對于Post方式提交的數(shù)據,可以使用request.setCharacterEncoding("gb2312");來明確指定獲取請求參數(shù)時使用編碼。但是此種方式只對Post方式提交有效。
創(chuàng)新互聯(lián)主營??诰W站建設的網絡公司,主營網站建設方案,app軟件開發(fā),??趆5小程序開發(fā)搭建,??诰W站營銷推廣歡迎??诘鹊貐^(qū)企業(yè)咨詢request.setCharacterEncoding("gb2312");對GET方式提交無效的原因是:該代碼只設置請求實體的編碼,而GET提交的數(shù)據是存放在請求行中的[資源名?param1="張三"¶m2=123],所以對GET請求的方式無效。
對于Get方式提交的數(shù)據,就只能手動解決亂碼:
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可以指定服務器在獲取請求參數(shù)時默認使用的編碼。
在servlet中通常會使用到如下幾個語句來解決中文亂碼問題:
request.setCharacterEncoding()是設置從request中取得的值或從數(shù)據庫中取出的值。
response.setContentType()目的是為了控制瀏覽器的行為,即控制瀏覽器用指定編碼進行解碼(指定HTTP響應的編碼,同時指定瀏覽器顯示的編碼)。
response.setCharacterEncoding()目的是用于response.getWriter()輸出的字符串的亂碼問題;如果是response.getOutputStream()是不需要此種解決方案的,因為這句話的意思是為了將response對象中的數(shù)據以UTF-8解碼后發(fā)向瀏覽器。
response.getOutputStream().write("中文".getBytes())輸出數(shù)據,這是一個字節(jié)流,寫入內存使用什么編碼,輸出就使用什么編碼。
以上就是java參數(shù)亂碼問題解決方法的詳細內容,更多請關注創(chuàng)新互聯(lián)成都網站設計公司其它相關文章!
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。