详解解决使用axios发送json后台接收不到的问题
2018-06-27 09:11
2887 查看
问题描述
按照axios官网例子发起请求传递json,后台接受到的数据为空,一直卡在options阶段。
尝试的方法
开始以为是接口有问题,使用postman测试下,一切正常,百思不得其解,看了好多issue也解决不了,加了
headers:{'content-type':'application/json'}也没用。
官网上是说,传json就按
application/json进行处理,然而并没有卵用;之后套了一层
JSON.stringify(data),
content-type又变成表单格式了==。
然后翻自己之前的代码,发现写法如出一辙,怀疑是版本号的问题,然而并不是==。。。。考虑到可能和服务端有关系。
原代码如下:
import axios from 'axios'; export default function request(url, params) { return axios.post(`xxxxxx/${url}`, params) .then((response) => { console.log('response', response); return response; }) .catch((error) => { console.log('error', error); return error; }); }
最后想想还是用fetch吧(确实用了,发现还是有这个问题,现在深度怀疑是服务端将参数类型卡的太死了,还有polyfill的问题就放弃了,如果有知道的小伙伴请留言告诉我,谢谢),实在不行就ajax(还要封装成promise,哭)。出于对axios的坚持,终于找到了解决方法。
解决方法
就是添加qs库,将json序列化之后传递,详见这个issue。
代码:
import axios from 'axios'; import qs from 'qs'; export default function request(url, params) { return axios.post(`https://xxxxxxxx/${url}`, qs.stringify(params)) .then((response) => { console.log('response', response); return response; }) .catch((error) => { console.log('error', error); return error; }); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 解决SpringMVC接收不到axios发送post请求的数据问题
- 解决java使用axios.js的post请求后台时无法接收到入参的问题
- Android使用wifi通过UDP协议发送广播数据包给PC接收不到问题解决方法
- 解决angular的post请求后SpringMVC后台接收不到参数值问题的方法
- springMVC_json格式数据的接收和发送(未解决中文乱码问题)
- 前端使用Jquery的getJSON方法,后台使用PHP,解决IE和火狐Firefox中存在的跨域ajax请求问题。
- 解决sina邮箱发送到cPanel邮件,接收不到邮件的问题
- 解决angular的post请求后SpringMVC后台接收不到参数值问题的方法
- 安卓使用Socket发送中文,C语言服务端接收乱码问题解决方式
- 解决angular的$http.post()提交数据时后台接收不到参数值问题的方法
- springMVC_json格式数据的接收和发送(未解决中文乱码问题)
- 解决SpringMvc后台接收json数据中文乱码问题
- ajax发送请求,后台接收不到的问题
- springMVC使用@RequestBody接收Json的过程,解决415的问题ss
- Android—Volley:接收服务端发送的json数据乱码问题解决
- Jsoncpp使用详解以及链接问题解决
- Android socket 使用PrintWriter和BufferedReader发送和接收出现乱码问题解决
- 使用Outlook发送邮件至移动设备导致移动设备接收winmail.dat问题解决方法
- VB中多个Winsock连续发送出现接收不到的异常问题解决方法
- 解决angular的$http.post()提交数据时后台接收不到参数值问题的方法