您的位置:首页 > 其它

url 传值中文乱码问题解决

2017-04-13 10:35 281 查看
转自: http://blog.csdn.net/yangyz_love/article/details/7963497  
URL参数中有中文值,传到服务端,在用request.getParameter()方法,得到的常常会是乱码。
 

这将涉及到字符解码操作,我们在应用中常常会用new String(fieldType.getBytes("iso-8859-1"), "UTF-8");等类似的方法去解码。但这种方式受具体应用环境限制,往往在应用部署环境发生改变时,还会出现中文乱码。
 

在这里介绍一种解决方法,可以在任何应用部署环境下通用。此方法分两步:
 

1、在客户端用escape(encodeURIComponent(fieldValue))方法编码,例如:
 

title=escape(encodeURIComponent(title)); //这是js里的函数
 

 url="<%=request.getContextPath()%>/print/printList!printTable.action?title="+title;
 

2、在服务端用java.net.URLDecoder.decode(getRequest().getParameter("title"),"UTF-8"),进行解码。
 

 
 

-----------------------------------------------------------------------------
 

parent.window.location.href 和 iframe中src的乱码问题。
 

要在这两个url地址中传中文,必须加编码,然后再解码。
 

编码:encodeURI(encodeURI("包含中文的串"))
 

解码:java.net.URLDecoder.decode("需要解码的串","utf-8");
 

 

encodeURI方法是正确的,只是需要使用两次encodeURI方法,例如encodeURI(encodeURI("中文"));第一次是 把中文编码成%xy的格式,第二次是对%xy中的%进行编码,%编码成%25。整个传参过程大体应该是:提交页面使用 encodeURI(encodeURI("中文"))编码,把最后的编码结果%25xy传递给处理页面的过程中,浏览器获取URL地址(注意 openModelDialog方法,浏览器获取不到参数编码)后解码成%xy,然后把%xy传递给处理页面,处理页面使用 URLDecoder.decode(request.getParameter("参数名"),"UTF-8");完成解码。
总结:
1、汉字出现在URL路径部分的时候不需要编码解码;
2、使用encodeURI进行2次编码;
3、在openModelDialog()打开的模式窗体里没办法用request.getParameter正确获取参数;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: