前端 POST/PUT/PATCH 给后端的数据方式

本文介绍了前端通过POST、PUT、PATCH三种方式向后端提交数据,包括原生form的键值对提交、文件的二进制上传以及JSON数据的传递。JSON方式会触发HTTP CORS机制,需要后端处理跨域问题。同时,讨论了URI中字符编码的重要性以及相关编码函数的使用。

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

前端 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 之外的所有字符。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值