HTTP常見Content-Type比較
阿新 • • 發佈:2019-01-02
1. application/x-www-form-urlencoded
最常見的 POST
提交資料的方式了。瀏覽器的原生 form 表單,如果不設定 enctype
屬性,那麼最終就會以 application/x-www-form-urlencoded
方式提交資料。
傳遞的key/val會經過URL轉碼,所以如果傳遞的引數存在中文或者特殊字元需要注意。
//例子
//b=曹,a=1
POST HTTP/1.1(CRLF)
Host: www.example.com(CRLF)
Content-Type: application/x-www-form-urlencoded(CRLF)
Cache -Control: no-cache(CRLF)
(CRLF)
b=%E6%9B%B9&a=1(CRLF)
//這裡b引數的值"曹"因為URL轉碼變成其他的字串了
2. text/xml
//例子
POST http://www.example.com HTTP/1.1(CRLF)
Content-Type: text/xml(CRLF)
(CRLF)
<?xml version="1.0"?>
<resource>
<id>123</id>
<params>
<name>
<value >homeway</value>
</name>
<age>
<value>22</value>
</age>
</params>
</resource>
3.application/json
//例子
//傳遞json
POST HTTP/1.1(CRLF)
Host: www.example.com(CRLF)
Content-Type: application/json(CRLF)
Cache-Control: no-cache(CRLF )
Content-Length: 24(CRLF)
(CRLF)
{
"a":1,
"b":"hello"
}
4. multipart/form-data
使用表單上傳檔案時,必須讓 form
的 enctyped
等於這個值。
並且Http協議會使用boundary來分割上傳的引數
//例子
//a="曹",file1是一個檔案
POST HTTP/1.1(CRLF)
Host: www.example.com(CRLF)
//注意data;和boundary之間有一個空格,並且----WebKitFormBoundary7MA4YWxkTrZu0gW是可以自定義的
Content-Type: multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW(CRLF)
Cache-Control: no-cache(CRLF)
Content-Length: 728
(CRLF)
//如果有Content-Length的話,則Content-Length指下面所有的位元組總數,包括boundary
//這裡用自定義的boundary來進行分割,注意會在頭部加多"--"
------WebKitFormBoundary7MA4YWxkTrZu0gW(CRLF)
Content-Disposition: form-data; name="a"(CRLF)
(CRLF)
曹(CRLF)
------WebKitFormBoundary7MA4YWxkTrZu0gW(CRLF)
Content-Disposition: form-data; name="file1"; filename="1.jpg"
Content-Type: application/octet-stream(CRLF)
(CRLF)
//此處是引數file1 對應的檔案的二進位制資料
[654dfasalk;af&6…](CRLF)
//最後一個boundary會分別在頭部和尾部加多"--"
------WebKitFormBoundary7MA4YWxkTrZu0gW--(CRLF)
//多個檔案同時上傳
POST HTTP/1.1(CRLF)
Host: www.example.com(CRLF)
//注意data;和boundary之間有一個空格,並且----WebKitFormBoundary7MA4YWxkTrZu0gW是可以自定義的
Content-Type: multipart/form-data; boundary=---------------------------418888951815204591197893077
Cache-Control: no-cache(CRLF)
Content-Length: 12138(CRLF)
(CRLF)
-----------------------------418888951815204591197893077(CRLF)
// 檔案1的頭部boundary
Content-Disposition: form-data; name="userfile[]"; filename="檔案1.md"(CRLF)
Content-Type: text/markdown(CRLF)
(CRLF)
// 檔案1內容開始
// ...
// 檔案1內容結束
-----------------------------418888951815204591197893077(CRLF)
// 檔案2的頭部boundary
Content-Disposition: form-data; name="userfile[]"; filename="檔案2"(CRLF)
Content-Type: application/octet-stream(CRLF)
(CRLF)
// 檔案2內容開始
// ...
// 檔案2內容結束
-----------------------------418888951815204591197893077(CRLF)
// 檔案3的頭部boundary
Content-Disposition: form-data; name="userfile[]"; filename="檔案3"(CRLF)
Content-Type: application/octet-stream(CRLF)
(CRLF)
// 檔案3內容開始
// ...
// 檔案3內容結束
-----------------------------418888951815204591197893077(CRLF)
// 引數username的頭部boundary
Content-Disposition: form-data; name="username"(CRLF)
(CRLF)
zhangsan
-----------------------------418888951815204591197893077(CRLF)
// 引數password的頭部boundary
Content-Disposition: form-data; name="password"(CRLF)
(CRLF)
zhangxx
-----------------------------418888951815204591197893077--
// 尾部boundary,表示結束
注意
(CRLF)
指\r\n