当前位置:   article > 正文

POST的4种请求方式_post请求

post请求

1 application/x-www-form-urlencoded

这应该是最常见的 POST 提交数据的方式了。浏览器的原生 form 表单,如果不设置 enctype 属性,那么最终就会以 application/x-www-form-urlencoded 方式提交数据。请求类似于下面这样(无关的请求头在本文中都省略掉了):

  1. POST http://www.example.com HTTP/1.1
  2. Content-Type: application/x-www-form-urlencoded;charset=utf-8
  3. title=test&sub%5B%5D=1&sub%5B%5D=2&sub%5B%5D=3
Content-Type 被指定为 application/x-www-form-urlencoded;提交的数据按照 key1=val1&key2=val2 的方式进行编码,key 和 val 都进行了 URL 转码。大部分服务端语言都对这种方式有很好的支持。

2.multipart/form-data

这又是一个常见的 POST 数据提交的方式。我们使用表单上传文件

  1. POST http://www.example.com HTTP/1.1
  2. Content-Type:multipart/form-data; boundary=----WebKitFormBoundaryrGKCBY7qhFd3TrwA
  3. ------WebKitFormBoundaryrGKCBY7qhFd3TrwA
  4. Content-Disposition: form-data; name="text"
  5. title
  6. ------WebKitFormBoundaryrGKCBY7qhFd3TrwA
  7. Content-Disposition: form-data; name="file"; filename="chrome.png"
  8. Content-Type: image/png
  9. PNG ... content of chrome.png ...
  10. ------WebKitFormBoundaryrGKCBY7qhFd3TrwA--

这种方式,首先生成了一个 boundary 用于分割不同的字段。然后 Content-Type 里指明了数据是以 mutipart/form-data 来编码,每部分都是以 --boundary 开始,紧接着内容描述信息,然后是回车。可以看到content里面也是键值对的形式传给后台。和第一种的区别在于,第二种的value可以是文件file

3. application/json

很多老牌的服务器为了安全,会选择这种方式。特点是content里面存放的,标准格式的json。也就是序列化的json。

  1. POST http://www.example.com HTTP/1.1
  2. Content-Type: application/json; charset=utf-8
  3. {"title":"test","sub":[1,2,3]}

 

 

4.text/xml

几乎没用到过。自行百度~

 

本文内容由网友自发贡献,转载请注明出处:https://www.wpsshop.cn/w/正经夜光杯/article/detail/850005
推荐阅读
  

闽ICP备14008679号