axios请求JSON问题详解

  1. 当参数是JSON对象时,默认的Content-Type是application/json。

    axios.post('/user', {
        firstName: 'Fred',
        lastName: 'Flintstone'
      })
      .then(function (response) {
        console.log(response);
      })
      .catch(function (error) {
        console.log(error);
      });

    此时传递的参数是Request Payload格式{firstName:"Fred",lastName:"Flintstone"}

    如果出现No 'Access-Control-Allow-Origin' header is present on the requested resource的错误,则是跨域问题。本人喜欢直接配置服务器来解决跨域:例如Nginx配置:Nginx配置跨域请求

  2. 当参数是JSON字符串时,默认的Content-Type是application/x-www-form-urlencoded。

    axios.post('/user', JSON.stringify({
        firstName: 'Fred',
        lastName: 'Flintstone'
      }))
      .then(function (response) {
        console.log(response);
      })
      .catch(function (error) {
        console.log(error);
      });

    此时传递的参数是Form Data格式key : value

    {"firstName":"Fred","lastName":"Flintstone"}:

    如上。其实这是一个无效的数据,key为{"firstName":"Fred","lastName":"Flintstone"},value为空。

  3. 要想使用application/x-www-form-urlencoded格式,需要进行数据转换,虽然有两种方式URLSearchParamsqs两种方式。我更喜欢使用qs库的方式,代码如下:

    axios.interceptors.request.use((req) => {
        if (req.method === 'post') {
         req.data = qs.stringify(req.data);
        }
        return req;
    }, (error) => Promise.reject(error));

    之后使用axios的时候,只需要传递json对象就可以:

    axios.post('/user', {
        firstName: 'Fred',
        lastName: 'Flintstone'
      })
      .then(function (response) {
        console.log(response);
      })
      .catch(function (error) {
        console.log(error);
      });
  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在使用axios发送网络请求时,可以通过headers配置参数来自定义请求头。以下是常用的请求头配置: 1. `Content-Type`:设置请求体数据格式,常见的有`application/json`、`application/x-www-form-urlencoded`、`multipart/form-data`等,其中`application/json`表示请求体数据为JSON格式,`application/x-www-form-urlencoded`表示请求体数据为URL编码格式。 2. `Authorization`:设置请求的认证信息,常见的有`Bearer token`、`Basic username:password`等,其中`Bearer token`表示使用JWT(JSON Web Token)方式进行认证,`Basic username:password`表示使用HTTP基本认证方式进行认证。 3. `Accept`:设置请求期望的响应数据格式,常见的有`application/json`、`text/html`、`text/plain`等,其中`application/json`表示期望响应数据为JSON格式,`text/html`表示期望响应数据为HTML格式。 4. `User-Agent`:设置客户端标识,常见的有`Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36`等,其中`Mozilla`表示浏览器类型,`Windows NT 10.0`表示操作系统类型,`Chrome/58.0.3029.110`表示浏览器版本号。 以下是一个完整的axios请求示例,包括请求头的配置: ``` import axios from 'axios'; axios.defaults.baseURL = 'http://example.com/api'; axios.defaults.headers.common['Authorization'] = 'Bearer token'; axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded'; axios.post('/login', { username: 'admin', password: 'password' }).then(response => { console.log(response.data); }).catch(error => { console.error(error); }); ``` 在以上示例中,我们设置了请求的基础URL为'http://example.com/api',并在请求头中添加了一个名为'Authorization'的字段,其值为'token',还设置了POST请求请求体数据格式为URL编码格式。我们发送了一个POST请求请求体数据为一个包含用户名和密码的对象,最后我们使用了Promise的方式处理了请求的响应和错误。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值