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

   今天在测试网站搜索功能的时候发现从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"); //对中文编码进行解码
 }这样得到的都是正常的中文了,乱码问题解决。
 
 

                
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值