get请求400错误 vue_IE浏览器http请求,中文传参报400错误-解决方法

做项目时,一个GET请求列表数据的接口在其他浏览器正常,但在IE浏览器出现400错误。经尝试发现,参数带中文会出现此情况。解决方法是将传递的中文参数进行编码,如使用js的encodeURI函数,同时添加时间戳避免缓存,即可解决问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

做项目的时候,遇到一个小的问题.一个get请求列表数据的接口,在其它浏览器上是可以正常请求的.但是在ie浏览器上确出现奇怪的http请求400错误,其含义是你访问的页面域名不存在或者请求错误,自己的本地,肯定没问题.那就是请求错误了.几经尝试发现是参数带中文的会出现此种情况,没带中文的没有问题.

如图(不带中文的参数返回的内容):

如图(带中文的参数):

以上可以发现,如果传参是中文的接口,返回是400,其余的参数都可以正常请求。

解决方法:将传递的参数进行编码,然后传递给后台,js编码encodeURI(中文参数),

//获取菜单列表数据

getMenulist: function() {

let that = this;

//兼容IE浏览器相同接口,有缓存,需要添加时间戳

let time=new Date().getTime();

//兼容IE浏览器传递中文,解码后可以正常请求

let name = encodeURI(that.menuName);

that.axios.get(api + '/sysmenutree/select2?treename=' +name+'&time='+time).then(function(response) {

var flag = response.data.flag;

var data = JSON.parse(response.data.data);

if(flag == 'true') {

that.menuData = data;

}else {

that.menuData = [];

that.$message.error(response.data.mes);

}

}).catch(function(error) {

console.log(error);

})

},

就可以解决传递中文参数,在IE浏览器没有反应的问题了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值