平常我們都是encode 一次,然后直接接受參數
String para = request.getParameter(paramName); 這是因為容器自動能幫我們解碼 (DECODE)
一般來說, encode 的時候,使用的 UTF-8(系統的 編碼) 那么解碼的時候也是使用 UTF-8的話, 那么不會出現傳說中的亂碼~
但是如果 在JSP 頁面 使用的UTF-8,但是 容器 解碼的時候 使用的 別的編碼的話,則有可能出現亂碼
這個時候.一般可以使用:
String param = new String(request.getParameter(paramName).getBytes("ISO-8859-1"),"UTF-8");
也能出來.
所有的手段都使了.還是搞不定怎么辦?
怎么解決這種多服務器導致的 編碼 問題:
假設 字符串: = "陽";
Encode 一次 %E9%98%B3
Encode 兩次 %2525E9%252598%2525B3
在第二次的時候 ,容器自動解的這一次,不管是按 GBK 還是 UTF-8 還是 ISO-8859-1 都好,都能夠正確的得到 %E9%98%B3
那么 只要自身在進行 Decode 一次 就能得到 "陽"
新聞熱點
疑難解答