jquery使用ajax有时候乱码,解决办法

$.ajax({
    dataType : ‘json’     ,
type : ‘POST’     ,
url : ‘http://localhost/test/test.do’     ,
data : {id: 1, type: ‘商品’}     ,
success : function(data){             } } );

问题:
  提交后后台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方法中加入以下参数
  
contentType: "application/x-www-form-urlencoded; charset=UTF-8"
使用其它js框架或者xhr都是差不多,设置header中contentType即可,
  这里关键是charset=UTF-8,如果没有这个,是不行的,默认jQuery里的contentType是没有的.

$.ajax({
dataType : 'JSON' ,
type : 'POST' ,
url : config.url + "?timestamp=" + new Date().getTime() ,
data : config.params ,
contentType: "application/x-www-form-urlencoded;charset=UTF-8" ,
success: config.callback
});

方法二在action里不需要进行decode,所以推荐使用此方法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值