HTTP Content-type 常用型別
阿新 • • 發佈:2020-12-01
幾個常用型別
1.application/x-www-form-urlencoded
1)瀏覽器的原生form表單
2) 提交的資料按照 key1=val1&key2=val2 的方式進行編碼,key和val都進行了URL轉碼
POST http://www.example.com HTTP/1.1 Content-Type: application/x-www-form-urlencoded;charset=utf-8 title=test&sub%5B%5D=1&sub%5B%5D=2&sub%5B%5D=3
2.multipart/form-data
常見的 POST 資料提交的方式。我們使用表單上傳檔案時,必須讓 form 的 enctype 等於這個值
<form action="/" method="post" enctype="multipart/form-data"> <input type="text" name="description" value="some text"> <input type="file" name="myFile"> <button type="submit">Submit</button> </form>
請求頭
POST /foo HTTP/1.1 Content-Length: 68137 Content-Type: multipart/form-data; boundary=---------------------------974767299852498929531610575 ---------------------------974767299852498929531610575 Content-Disposition: form-data; name="description" some text ---------------------------974767299852498929531610575 Content-Disposition: form-data; name="myFile"; filename="foo.txt" Content-Type: text/plain (content of the uploaded file foo.txt) ---------------------------974767299852498929531610575--
生成了一個 boundary 用於分割不同的欄位,為了避免與正文內容重複,boundary 很長很複雜。
然後 Content-Type 裡指明瞭資料是以 multipart/form-data 來編碼,本次請求的 boundary 是什麼內容。
訊息主體裡按照欄位個數又分為多個結構類似的部分,每部分都是以 --boundary 開始,緊接著是內容描述資訊,然後是回車,最後是欄位具體內容(文字或二進位制)。
如果傳輸的是檔案,還要包含檔名和檔案型別資訊。訊息主體最後以 --boundary-- 標示結束
3.application/json
訊息主體是序列化後的 JSON 字串,這個型別越來越多地被大家所使用
POST http://www.example.com HTTP/1.1
Content-Type: application/json;charset=utf-8
{"title":"test","sub":[1,2,3]}
這種方案,可以方便的提交複雜的結構化資料,特別適合 RESTful 的介面。傳遞JSON字串可以方便的讓前端轉為js的物件,進行顯示和邏輯操作。
4.text/xml
是一種使用 HTTP 作為傳輸協議,XML 作為編碼方式的遠端呼叫規範
POST [http://www.example.com](http://www.example.com) HTTP/1.1 Content-Type: text/xml <!--?xml version="1.0"?--> <methodcall> <methodname>examples.getStateName</methodname> <params> <param> <value><i4>41</i4></value> </param> </params> </methodcall>
記錄下HTTP常見Content-type型別,方便自己學習,此文轉摘https://blog.csdn.net/u013453787/article/details/88224587,尊重他人勞動果實,哈哈哈