java request.getParameter中文亂碼解決方法
今天瀏覽項目時候,遇到一個問題,頁面用${requestScope.參數名 }獲取的值是亂碼,然后搜了一下,最后說是編碼的問題,附上查找的結果:
在Java 開發(fā)中,如果框架搭建的不完善或者初學者在學習過程中,出現中文亂碼是經常的事兒(哈。誰讓發(fā)明java語言的不是中國人呢)
今天跟大家分享幾個解決java Web開發(fā)中,request.getParameter()獲取URL中文參數亂碼的解決辦法
解決問題,先要研究問題,URL傳中文參數為什么會出現亂碼?
原因:Http請求傳輸時將url以ISO-8859-1編碼,服務器收到字節(jié)流后默認會以ISO-8859-1編碼來解碼成字符流(造成中文亂碼)
解決辦法:我們需要把request.getParameter(“參數名”)獲取到的字符串先用ISO-8859-1編碼成字節(jié)流,然后再將其用utf-8解碼成字符流
代碼:
String str = new String(request.getParameter("參數名").getBytes("iso-8859-1"), "utf-8");
這是通過轉碼的方式處理亂碼問題,我們也可以通過Tomcat配置文件,設置URL編碼集(URIEncoding)設置編碼,這種方法也是一勞永逸的,
修改Tomcat/conf 目錄下 server.xml
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8444" useBodyEncodingForURI="true" URIEncoding="UTF-8"/>
重點在 userBodyEncodingForURI 和 URIEncoding 這兩個屬性
下面來解釋一下這兩個屬性的意義
useBodyEncodingForURI參數表示是否用request.setCharacterEncoding參數對URL提交的數據和表單中GET方式提交的數據進行重新編碼,在默認情況下,該參數為false。
URIEncoding參數指定對所有GET方式請求進行統(tǒng)一的重新編碼(解碼)的編碼。
URIEncoding和useBodyEncodingForURI區(qū)別是
URIEncoding是對所有GET方式的請求的數據進行統(tǒng)一的重新編碼, 而useBodyEncodingForURI則是根據響應該請求的頁面的request.setCharacterEncoding參數對數據進行的重新編碼,不同的頁面可以有不同的重新編碼的編碼
還有一種方法,通過重寫getParameter方法,設置解碼/方式來解決亂碼問題,請參照:Java防止xss攻擊 修改。
相關文章
解決jasperreport導出的pdf每頁顯示的記錄太少問題
這篇文章主要介紹了解決jasperreport導出的pdf每頁顯示的記錄太少問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06