axios中http请求Content-Type以及post需要用qs.stringify而get请求时不用

一.前端向后端传输数据的方式

1.前端向后端传输数据时,有get和post两种:

如果是get传输,直接传在url后;如果是post传输,则在请求体body中传输。HTTP请求中的get请求和post请求参数的存放位置是不一样的。

2.在body中的数据格式(post请求):

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

  1. 如果后端接收json数据类型,post 的 headers 需要设置 { ‘content-type’: ’application/json’ },传给后端的数据就形如 { ‘name’:’edward’, ‘age’:’25’ }
  2. 如果后端接收的是(表单)字符串类型,post 的 headers 需设置 { ‘content-type’: ’application/x-www-form-urlencoded’ },传输给后端的数据就形如 ‘name=edward&age=25’
  3. multipart/form-data(一般用来上传文件)
  • 为什么一般是给post请求设置content-type,get请求不需要设置吗?
    get 请求一般没有消息体body,而content-type 是用来指定消息体的格式的

3.接口数据传输方式 form data、payload 和 Query String Parameters

POST提交数据有两种数据传输方式,这两种方式浏览器是通过Content-Type来进行区分:
如果是 application/x-www-form-urlencoded的话,则为formdata方式;
如果是application/json或multipart/form-data的话,则为 request payload

1)Form Data  Content-Type: ‘application/x-www-form-urlencoded’
在这里插入图片描述
2)Payload    Content-Type: ‘application/json; charset=utf-8’
在这里插入图片描述

如果是GET请求,则为Query String Parameters
在这里插入图片描述

二.qs.stringfy()

qs.stringfy()是将对象序列化成URL的形式,以&进行拼接。安装axios即可使用qs。

1.使用场景

axios默认数据格式为json,所以:
1.当后端需要接收json格式的数据时,post请求头不需要设置请求头,数据格式也不需要我们去转换(若数据已经是json);
2.当后端需要接收字符串格式的数据时,我们需要给post请求头设置{ ‘content-type’: ’application/x-www-form-urlencoded’ },
这个时候如果我们传的入参是一个 js 对象,这时候我们就需要用 qs 转换数据格式

2.如何处理对象和数组的

如果为对象,如 { name: ‘edward’, age: ‘25’ },jQuery 将自动转化为 ‘name=edward&age=25’
如果为数组,jQuery 将自动为不同值对应同一个名称。如 {foo:[“bar1”, “bar2”]} 转换为 ‘&foo=bar1&foo=bar2’。

3.可以在封装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';

4.JSON.stringfy() 和 qs.stringfy()区别

let  data = { name: 'edward', age: '25' }
前者:JSON.stringfy(data)  //  ”{ 'name' : 'edward' , 'age' : '25' }”
后者:qs.stringfy(data)  // 'name=edward&age=25'

5.是否需要用qs去序列化参数完全取决于后端要怎么接受数据

var qs = require("qs");
export const AxiosPost = (url, params) => { 
    return axios.post(url,qs.stringify(params), {headers: {"Content-Type": "application/x-www-form-urlencoded" } })
}

三.Content-Type

1.概念

Content-Type是指http/https发送信息至服务器时的内容编码类型,contentType用于表明发送数据流的类型,服务器根据编码类型使用特定的解析方式,获取数据流中的数据。

2.在网络请求中,常用的Content-Type有如下:

常见的页面资源类型:text/html, text/plain, text/css, text/javascript, image/jpeg, image/png, image/gif,
ajax的请求,表单提交或上传文件的常用的资源类型:application/x-www-form-urlencoded, multipart/form-data, application/json, application/xml 等。

3.服务端在取接口的请求参数

使用不同请求方式时,参数的传输方式是不一样的,但是服务端在取接口的请求参数时,用的方法其实却是一样的,都是使用request.getParameter(key)来获取
其实是因为tomcat在中间会对请求参数进行解析处理,处理完把解析出来的表单参数放在request parameter map中,所以后端就可以通过request.getParameter(key)来统一获取数据,而tomcat解析的时候是通过’contentType’来知道当前的请求是post请求,当’contentType’为"application/x-www-form-urlencoded",它才会去读取请求体数据。

那为何要用Qs.stringify()将对象序列化成URL的形式呢?
post请求参数是以键值对的形式存在请求体里,用Qs.stringify()就是把传入的对象转换为键值对。

转载:https://blog.youkuaiyun.com/JackieDYH/article/details/115513346

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值