1. 程式人生 > >HTTP常見Content-Type比較

HTTP常見Content-Type比較

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

使用表單上傳檔案時,必須讓 formenctyped 等於這個值。
並且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