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");

 

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