Ajax中文乱码问题及解决方法

场景:

使用jQuery的ajax方法提交ajax请求,代码如下:

1$.ajax( {
2
    dataType : 'json'
3
    ,type : 'POST'
4    ,url : 'http://localhost/test/test.do'
5    ,data : {id: 1, type: '商品'}
6    ,success : function(data)
{
7
        
8    }
9});


问题:

提交后后台action程序时,取到的type是乱码

解决方法:

方法一:提交前采用encodeURI两次编码,记住一定是两次
1.修改以下代码

data:{id:1, type:encodeURI(encodeURI('商品'))}

2.在后台action里要对取得的字符串进行decode

1String type = request.getParameter("type" );
2type = URLDecoder.decode(type, "UTF-8");


方法二:ajax配置contentType属性,加上charset=UTF-8
在ajax方法中加入以下参数

1contentType: "application/x-www-form-urlencoded; charset=UTF-8"

使用其它js框架或者xhr都是差不多,设置header中contentType即可,
这里关键是charset=UTF-8,如果没有这个,是不行的,默认jQuery里的contentType是没有的.
还补充一下jQuery里对参数已经进行了一次encodeURIComponent的处理

*方法二在action里不需要进行decode,所以推荐使用此方法

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值