axios中post请求json和application/x-www-form-urlencoded详解

文章详细介绍了在前端开发中,使用Axios进行POST请求时如何处理数据格式。当后端需要json格式,Axios默认设置即可;需要字符串格式时,需设置content-type并使用qs.stringify转换数据。同时对比了jQuery$.ajax的POST请求默认设置。还提到了JSON.stringify与qs.stringify的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

前端向后端传输数据时,如果是get传输,直接传在url后;如果是post传输,则在请求体body中传输。

在body中的数据格式又有两种,一种是  json  数据格式,另一种是 字符串。具体要用哪种格式取决于后端入参的格式。

如果后端接收json数据类型,post 的 headers 需要设置 { ‘content-type’: ’application/json’ },传给后端的数据就形如  { ‘name’:’edward’, ‘age’:’25’ } 

如果后端接收的是(表单)字符串类型,post 的 headers 需设置  { ‘content-type’: ’application/x-www-form-urlencoded’ },

,传输给后端的数据就形如   ‘name=edward&age=25’  

qs   

qs.stringfy() 将对象序列化成URL的形式

axios默认数据格式为json,所以:

1.当后端需要接收json格式的数据时,post请求头不需要设置请求头,数据格式也不需要我们去转换(若数据已经是json);

2.当后端需要接收字符串格式的数据时,我们需要给post请求头设置{ ‘content-type’: ’application/x-www-form-urlencoded’ },

   这个时候如果我们传的入参是一个 js 对象,这时候我们就需要用 qs 转换数据格式,qs具体用法如下:

 安装模块:npm  i  qs  -S

import qs from 'qs';
const data = { name:'edward' , age:'25'};  // 我们传的是 js 对象
const options = {
  method: 'POST',
  headers: { 'content-type': 'application/x-www-form-urlencoded' },
  data: qs.stringify(data),   // 用 qs 将js对象转换为字符串 'name=edward&age=25'
  url: 'http://www.edward.com'
}; axios(options);

我们也可以在封装axios的时候,给它全局设置qs 

axios.defaults.baseURL = 'https://api.example.com';
axios.defaults.headers.common['Authorization'] = AUTH_TOKEN;
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';

【区分】: JSON.stringfy()  和 qs.stringfy() 

  let  data = { name: 'edward', age: '25' }

  前者:JSON.stringfy(data)  //  ”{ 'name' : 'edward' , 'age' : '25' }”

  后者:qs.stringfy(data)  // 'name=edward&age=25'

【区分】:jQuery 中 $.ajax 的post请求  VS   axios的post 请求的 content-type 默认值

  前者:"application/x-www-form-urlencoded"

  后者:"application/json"

$.ajax({
   type: 'POST',
   contentType: 'application/json;charset=utf-8', // 发送的数据类型
   dataType: 'json',   // 接收的数据类型
   url: 'http://www.edward.com',
   data: JSON.stringfy(formData),
   success: function (res) {
      console.log(res.data)
   }
}) 

contentType: 告诉服务器,我要发什么类型的数据

dataType:告诉服务器,我要想什么类型的数据,如果没有指定,那么会自动推断是返回 XML,还是JSON,还是script,还是String。

注意 :$.ajax() post发送到服务器的数据。

将自动转换为请求字符串格式。

如果为对象,如 { name: 'edward', age: '25' },jQuery 将自动转化为 'name=edward&age=25'

如果为数组,jQuery 将自动为不同值对应同一个名称。如 {foo:["bar1", "bar2"]} 转换为 '&foo=bar1&foo=bar2'。

总结

到此这篇关于axios中post请求json和application/x-www-form-urlencoded详解的文章就介绍到这了,更多相关axios post请求json内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

在使用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的方式处理了请求的响应错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值