概述
前端 POST/PUT/PATCH 给后端的数据,主要有三类数据方式:
1、application/ x-www-form-urlencoded
2、multipart/form-data
3、application/json
第 1 类,原生 form 默认的提交方式,所有表单(扁平)数据会被处理成键值对形式(key1=value1&key2=value2
)发送给后端,其中 key/value 字符前端需要通过 encodeURIComponent
转码,后端接收后需要解码,不建议前端直接发送和后端直接接收使用,前后端要进行字符编码处理;
第 2 类,好理解,用于提交文件,将其处理成二进制数据提交给后端;
第 3 类,传递 JSON 给后端,适合传递结构复杂的数据对象,这种方式,会触发 HTTP CORS 机制,会有两次请求:
- i. 浏览器首先使用
OPTIONS
方法发起一个预检请求到服务器,以获知服务器是否允许该实际请求, - ii. 需要后端解决跨域问题,允许前端该跨域请求,浏览器发起实际请求;
前端 GET 后端数据,Query 部分数据,如,api.xxx.com/search/type?key1=value1&key2=value2
,其中 key/value 部分字符同样需要进行编码处理,同上。
做这些事目的,是为了处理 URI 中具有特殊含义的保留字符(reserved character)
ECMAScript Percent-encoding
-
encodeURIComponent(str)
,Not Escaped:
A-Z
a-z
0-9
-
_
.
!
~
*
'
(
)
即,
encodeURIComponent
转义除了上述 Not Escaped 之外的所有字符。
- axios/axios: Promise based HTTP client for the browser and node.js
- HTTP访问控制(CORS) - HTTP | MDN
- encodeURIComponent - JavaScript MDN
- File Upload using AngularJS - Stack Overflow
- Uploading Files With VueJS and Axios - Server Side Up
- How to Handle File Uploads in Vue 2 ― Scotch.io
最后
以上就是淡然火车为你收集整理的前端 POST/PUT/PATCH 给后端的数据方式的全部内容,希望文章能够帮你解决前端 POST/PUT/PATCH 给后端的数据方式所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复