您的位置:首页 > 其它

url传中文在IE中出现乱码问题处理

2014-10-13 13:58 344 查看
今天在测试网站搜索功能的时候发现从url传过去的中文名称全部成了乱码,导致查询功能失效,检查代码 的时候发现之前的人员没有对客户端跟服务端的字节编码进行统一,于是在服务端添加了以下代码(注:项目中已经统一了页面的字节编码为UTF8了):
String convertedString = new String(ret.getBytes("8859_1"), "UTF8");
再次测试的时候又出现了新的问题,在火狐跟谷歌浏览器中测试已经能正常显示中文了,但在IE中依然还是乱码,再次仔细检查代码,发现问题在哪了,之前开发人员直接在url中传中文参数,如果浏览器取值的编码不同就会导致最后得到的编码不一致,所以解决这个问题较简单的方法就是不要在url里直接传中文参数,只需要在客户端传参数之前把中文进行编码,在服务端取值的时候再进行解码就行了,下面是编码及解码的方法
客户端编码:
var chUrl = ...;//此处为url中的中文参数变量值
if(chUrl != null) {
  chUrl = escape(encodeURIComponent(chUrl )); //对中文字段进行编码
 }
服务端解码:
String chUrl = Util.getFullParameter(request, "chUrl ");//拿到编码后的中文字节,这里取值方法根据自己项目中封装的方法来取,大同小异
 if(chUrl != null && !chUrl .equals("")) {
  chUrl = java.net.URLDecoder.decode(chUrl ,"utf-8"); //对中文编码进行解码
 }这样得到的都是正常的中文了,乱码问题解决。




                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  url 中文 乱码