JAVA 中URL链接中文参数乱码的若干处理方法,目前整理收录如下:
方法一:
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" %>
<a href="ds.jsp?url=<%=java.net.URLEncoder.encode("编码的是这里","GB2312")%>">点击这里</a>
<%
//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",确保解码格式和编码格式统一;
方法四:
<script>
for(var i=0;i<document.links.length;i++){
document.links[i].href=encodeURI(document.links[i].href);
}
</script>
在action中,String s=request.getParameter("s");
s=new String(s.getBytes("iso-8859-1"),"gbk");
以上方法是收聚了一些网友所讲的解决方法 。
=====================================================================================
=====================================================================================
String encodeStr = java.net.URLEncoder.encode("编码的是这里","GBK");
System.out.println("编码后:"+encodeStr);
String decodeStr = java.net.URLDecoder.decode(encodeStr, "GBK");
System.out.println("解码后:"+decodeStr);
System.out.println("------------------------------------------");
String enc = "编码的是这里";
enc = new String(enc.getBytes(),"iso-8859-1");
System.out.println("enc="+enc);
String dec = new String(enc.getBytes("iso-8859-1"),"GBK");
System.out.println("dec="+dec);
输出结果:
编码后:%B1%E0%C2%EB%B5%C4%CA%C7%D5%E2%C0%EF
解码后:编码的是这里
------------------------------------------
enc=±à??????????
dec=编码的是这里