vue ajax post请求,Vue中用vue-resource POST请求接口时报错Uncaught (in promise)(错误码400)的解决方案...

问题描述:

项目中,难免会调用后台接口请求数据,当使用ajax向后端发送POST请求时,会成功调用接口;但是改用400 Bad Request 错误,错误提示Uncaught (in promise),接下来具体分析。

通过Ajax请求数据

用ajax请求时正常,如下:

08922c2af06075aaa85cf0e5b6bdcb78.png

http请求成功详情:

08922c2af06075aaa85cf0e5b6bdcb78.png

通过vue-resource请求数据

使用vue-resource中的post请求时就出现了错误,代码如下:

08922c2af06075aaa85cf0e5b6bdcb78.png

控制台报错Uncaught (in promise),错误码400,如下图:

08922c2af06075aaa85cf0e5b6bdcb78.png

http请求失败详情:

08922c2af06075aaa85cf0e5b6bdcb78.png

可以看出AJAX请求发送200 OK,而vue-resource请求发送400 Bad Request。

具体原因可以看出来在请求头中,前者的Content-Type=application/x-www-form-urlencoded,导致请求体中的数据格式为Form Data:id=1;而后者的Content-Type=application/json,导致请求体中的数据格式为Request PayLoad: { id:1 }。显然服务端接收第一种参数格式而拒绝第二种,所以抛出400状态码。

所以要做的就是将vue-resource请求体中的参数格式指定为Form Data即可。

emulateJSON

boolean类型 默认值为false

用途:将request body以application/x-www-form-urlencoded content-Type发送

在发送POST请求的options选项中添加{emulateJSON:true}即可。正确的http请求如下:

08922c2af06075aaa85cf0e5b6bdcb78.png

http请求成功详情:

08922c2af06075aaa85cf0e5b6bdcb78.png

总结

请求头中的Content-Type字段会说明实体主体内对象的媒体类型。AJAX默认的Content-Type=application/x-www-form-urlencoded;vue-resource的POST请求默认的Contnet-Type=application/json;通过指定emulateJSON的值来指定vue-resource Content-Type的值。

原创文章,作者:Ferrycoln,如若转载,请注明出处:https://ms200.cn/archives/370

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值