标签:
解决输入的全角汉字或者日文在URl中乱码的问题。以下我的实现
JS代码:function shiborikomuFw() {var url = ‘${url08}‘;var str = document.getElementsByName(‘fw‘);//Str str = document.getElementsById(‘fw‘).Value;for (var i = 0; i < str.length; i++) {url = url + "&fw=" + encodeURI(str[i].value);}window.location.href = url;}JAVA代码:String fw = (String) form.fw;if (fw != null && !"".equals(fw)){try{fw = new String(fw.getBytes("ISO-8859-1"),"UTF-8");// fw = java.net.URLDecoder.decode(fw, "UTF-8");form.fw = fw;}catch (Exception e){}}
这样就解决问题了,在其他情况下也会有乱码,以下转自网络的各种解决方法。做个记号,方便大家查阅。
http://xxx.do?ptname=‘我是中国人‘String strPtname = request.getParameter("ptname");strPtname = new String(strPtname.getBytes("ISO-8859-1"), "UTF-8");
<%@ page contentType="text/html;charset=gb2312" %><%//request.setCharacterEncoding("GBK");if(request.getParameter("url")!=null){str=request.getParameter("url");str=java.net.URLDecoder.decode(str,"GB2312");str=new String(str.getBytes("ISO-8859-1"));out.print(str);}%>==================================public String chinatoString(String str){String s=str;try{byte tempB[]=s.getBytes("ISO-8859-1");s=new String(tempB);return s;}catch(Exception e){return s;}}====================================================function URLencode(sStr){return escape(sStr).replace(//+/g, ‘%2B‘).replace(//"/g,‘%22‘).replace(//‘/g, ‘%27‘).replace(////g,‘%2F‘);}
如果用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",确保解码格式与编码格式统一;
方法四:
在action中,
String s=request.getParameter("s");s=new String(s.getBytes("iso-8859-1"),"gbk");
四种方法应该都没问题,我已经测试过了。
标签:
原文地址:http://www.cnblogs.com/kesar/p/4926364.html