jquery的serialize和getJson导致中文乱码的案例学习

最近在写一个小工具,使用jquery的serialize数据后调用getJson,结果返回的中文乱码。

用了半天的时间来尝试解决乱码问题,依然没有效果。后来偶然发现(如下图),当serialize的中文为“哈哈”时,返回的json数据确是三个字符,这是什么问题呢?


可以在很短的时间内看到,浏览器url中的“哈哈”最初是一个url编码,浏览器自动将其转换为中文“哈哈”,于是怀疑serialize的编码后传递到后端,后端将其解析成了三个字符,其实是没有乱码的,只是这三个字符本身就是乱码。

通过google,找到了解决方法:对serialize后的数据进行decodeURIComponent:

var params = jQuery("#formId").serialize(); 
 params = decodeURIComponent(params,true);


还有两种方法:

1.将jquery.js文件中的encodeURIComponent替换为encodeURI

2.将所有jsp、xml的字符集都设置为UTF-8 


为什么要这样做呢?

serialize默认使用的是encodeURIComponent进行编码,即utf-8编码,中文“哈哈”被编码为“%E5%93%88%E5%93%88”,即一个“哈”被编码为三个字节。

浏览器识别出“%E5%93%88%E5%93%88”,将自动将其转码为gbk的中文“哈哈”。

但是服务器端使用的是gbk编码,一个中文被编码为两个字节,即“哈哈”被解析成了三个字符。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值