JAVA 中URL中文參數亂碼的處理方法(彙總)

解決輸入的全角漢字或者日文在URl中亂碼的問題。以下我的實現

 

JSP代碼:

  1. function shiborikomuFw() {                                      
  2.     var url = '${url08}';                                   
  3.     var str = document.getElementsByName('fw');             
  4.         //Str str = document.getElementsById('fw').Value;               
  5.     for (var i = 0; i < str.length; i++) {                                  
  6.         url = url + "&fw=" + encodeURI(str[i].value);                               
  7.     }               
  8.     window.location.href = url;
  9. }

JAVA代碼:

  1.         String fw = (String) form.fw;                   
  2.         if (fw != null && !"".equals(fw)) {                 
  3.             try {                   
  4.                 fw = new String(fw.getBytes("ISO-8859-1"),"UTF-8");             
  5.                // fw = java.net.URLDecoder.decode(fw, "UTF-8");                 
  6.                 form.fw = fw;                   
  7.             } catch (Exception e) {}                    
  8.         }

這樣就解決問題了,在其他情況下也會有亂碼,以下轉自網絡的各種解決方法。做個記號,方便大家查閱。

 

方法一:

  1. http://xxx.do?ptname='我是中國人' 
  2. String strPtname = request.getParameter("ptname"); 
  3. strPtname = new String(strPtname.getBytes("ISO-8859-1"), "UTF-8");   

方法二:

  1. <%@ page contentType="text/html;charset=gb2312" %> 
  2. <a href="ds.jsp?url=<%=java.net.URLEncoder.encode("編碼的是這裏","GB2312")%>">點擊這裏</a> 
  3. <% 
  4. //request.setCharacterEncoding("GBK"); 
  5. if(request.getParameter("url")!=null
  6. str=request.getParameter("url"); 
  7. str=java.net.URLDecoder.decode(str,"GB2312"); 
  8. str=new String(str.getBytes("ISO-8859-1")); 
  9. out.print(str); 
  10. %> 
  11. ================================== 
  12. public String chinatoString(String str) 
  13.      { 
  14.       String s=str; 
  15.       try 
  16.       { 
  17.        byte tempB[]=s.getBytes("ISO-8859-1"); 
  18.        s=new String(tempB); 
  19.        return s; 
  20.       } 
  21.       catch(Exception e) 
  22.       { 
  23.        return s; 
  24.       } 
  25.     } 
  26. ==================================================== 
  27. function URLencode(sStr) 
  28.     { 
  29.       return escape(sStr). 
  30.                replace(//+/g, '%2B'). 
  31.                   replace(//"/g,'%22'). 
  32.                      replace(//'/g, '%27'). 
  33.                        replace(////g,'%2F'); 
  34.     } 

方法三: 

如果用jstl的話,可以自己寫一個el的function,調用URLEncoder.encode來編碼。 

IE缺省對URL後面的參數是不編碼發送的,但是tomat缺省是按ISO8859-1來進行URL解碼,因此纔會出現上述錯誤。好的做法是: 

1、在URL參數中確保用UTF-8編碼之,方法可以用js函數encodeURI(),或調用自定義的el function; 

2、設置server.xml中的Connector熟悉URIEncoding="UTF-8",確保解碼格式與編碼格式統一;

 

方法四:

  1. <script> 
  2. for(var i=0;i<document.links.length;i++){ 
  3. document.links[i].href=encodeURI(document.links[i].href); 
  4. </script> 
  5. 在action中,String s=request.getParameter("s"); 
  6. s=new String(s.getBytes("iso-8859-1"),"gbk");

 

四種方法應該都沒問題,我已經測試過了。
發佈了25 篇原創文章 · 獲贊 24 · 訪問量 15萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章