美文网首页让前端飞Web 前端开发 前端之美-VueJs
解决使用axios发送json后台接收不到的问题

解决使用axios发送json后台接收不到的问题

作者: mytac | 来源:发表于2018-06-26 15:13 被阅读209次

    问题描述

    按照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;
            });
    }
    

    相关文章

      网友评论

      • samfung09:哎呀,今晚遇到这个问题了,查了两三个小时,话说以前axios不是很简单的直接就可以发送json的吗
        mytac:是的啊,我也不太清楚,我之前用没出现过这个问题,但貌似不是版本的事。
      • p了个f:这个问题好像早都有,我记得思否里面有相关解决方案。就是需要序列化
        mytac:@p了个f 好像不是版本的问题,我觉得可能跟后端语言有关系?之前是java和node就没有这个情况
        p了个f:@张君卓 我也不知道,听朋友说,所有的post提交都是必须序列画下。以前的版本可能已经自己做了,新版本估计把这个取消了
        mytac:是的,但是不知道为什么,之前用axios并没有出现过这个问题

      本文标题:解决使用axios发送json后台接收不到的问题

      本文链接:https://www.haomeiwen.com/subject/xncmyftx.html