问题描述
按照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; }); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
狼山资源网 Copyright www.pvsay.com
暂无“详解解决使用axios发送json后台接收不到的问题”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。