zoukankan      html  css  js  c++  java
  • axios的post请求后台(ThinkPHP5)接收不到数据

    最近做vue项目,做分页的功能,使用post给后台发送数据,使用接口还是工具(postman)都可获取数据,唯独axios获取不到;经过排除,发现这与axios的post传参格式有关系;

     this.$axios({
        method: 'post',
        url:url,
        params: {
            seller_id:seller_id
        }
    }).then((res)=>{
     
    })
    

    在使用axios时,要注意到配置选项中包含params和data两者,以为他们是相同的,实则不然。
    因为params是添加到url的请求字符串中的,用于get请求。而data(form-data)是添加到请求体(body)中的, 用于post请求。

    解决方法

    方法1:

    配置如下:
    在main.js里 设置配置,修改Content-Type

    import axios from 'axios';
    axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
    Vue.prototype.$axios = axios;
    

    Content-Type须配置为application/x-www-form-urlencoded,以数据量格式进行数据传输(不兼容ie)

    方法2:(推荐)

    安装qs,在 main.js里引入并且对数据进行序列化

    import axios from 'axios';
    import qs from 'qs';
    Vue.prototype.$qs = qs;
    

    或者

    import qs from 'qs';
    axios.interceptors.request.use((config) => {
        config.data = qs.stringify(config.data);
        return config;
    }, function(error) {
        return Promise.reject(error);
    });
    

    作者:子恒|haley
    博客园:http://www.cnblogs.com/mylly/
    版权所有,欢迎保留原文链接进行转载:)

  • 相关阅读:
    (转) IOS ASI http 框架详解
    不是技术牛人 如何拿到IT巨头的Offer 来自作者: lsldd 来源: CSDN
    数据类型Block 粗解
    GCD的基本思想
    自定义Cell的 两种方法!
    全世界最幸运的我
    实现鸢尾花数据的读入
    Tensorflow2的基本用法
    6.17
    6.16
  • 原文地址:https://www.cnblogs.com/mylly/p/9902780.html
Copyright © 2011-2022 走看看