我們在平時(shí)的postman請求調(diào)試,以及web的http請求開發(fā)時(shí),常常能看到以下幾種傳參的形式 form-data、x-www-form-urlencoded、raw、binary,那么這些請求方式的區(qū)別是什么呢?

1、form-data:
就是http請求中的multipart/form-data,它會將表單的數(shù)據(jù)處理為一條消息,以標(biāo)簽為單元,用分隔符分開。既可以上傳鍵值對,也可以上傳文件。當(dāng)上傳的字段是文件時(shí),會有Content-Type來說明文件類型;content-disposition,用來說明字段的一些信息;
由于有boundary隔離,所以multipart/form-data既可以上傳文件,也可以上傳鍵值對,它采用了鍵值對的方式,所以可以上傳多個(gè)文件。

上圖中我們可以看到在postman中form-data選項(xiàng),key是有下拉選擇項(xiàng)的,這也說明了form-data類型支持key-value和文件傳輸。

上圖中我們可以看到,明顯的不同的key參數(shù)之間是有boundary分割的。每個(gè)參數(shù)都有Content-Disposition: form-data; name="xxx"信息
2、x-www-form-urlencoded:
就是application/x-www-from-urlencoded,會將表單內(nèi)的數(shù)據(jù)轉(zhuǎn)換為鍵值對,比如,name=java&age = 23

我們可以看到,這個(gè)形式的傳參方式,postman的key是并沒有像form-data一樣改出File的下拉選項(xiàng)的,這也說明了這種方式只支持string的key-value值傳遞。

在上圖中我們也能明顯的看到在http的body體中傳輸?shù)母袷健M瑫r(shí)我們也看到對于存在中文和空格的情況,它是會進(jìn)行轉(zhuǎn)換的。
1、它是post的默認(rèn)格式,使用js中URLencode轉(zhuǎn)碼方法。包括將name、value中的空格替換為加號;將非ascii字符做百分號編碼;將input的name、value用‘=’連接,不同的input之間用‘&’連接。
2、百分號編碼什么意思呢。比如漢字‘丁’吧,他的utf8編碼在十六進(jìn)制下是0xE4B881,占3個(gè)字節(jié),把它轉(zhuǎn)成字符串‘E4B881’,變成了六個(gè)字節(jié),每兩個(gè)字節(jié)前加上百分號前綴,得到字符串“%E4%B8%81”,變成九個(gè)ascii字符,占九個(gè)字節(jié)(十六進(jìn)制下是0x244534254238253831)。把這九個(gè)字節(jié)拼接到數(shù)據(jù)包里,這樣就可以傳輸“非ascii字符的 utf8編碼的 十六進(jìn)制表示的 字符串的 百分號形式”,_。
3、同樣使用URLencode轉(zhuǎn)碼,這種post格式跟get的區(qū)別在于,get把轉(zhuǎn)換、拼接完的字符串用‘?’直接與表單的action連接作為URL使用,所以請求體里沒有數(shù)據(jù);而post把轉(zhuǎn)換、拼接后的字符串放在了請求體里,不會在瀏覽器的地址欄顯示,因而更安全一些。
4、對于一段utf8編碼的字節(jié),用application/x-www-form-urlencoded傳輸其中的ascii字符沒有問題,但對于非ascii字符傳輸效率就很低了(漢字‘丁’從三字節(jié)變成了九字節(jié)),因此在傳很長的字節(jié)(如文件)時(shí)應(yīng)用multipart/form-data格式。smtp等協(xié)議也使用或借鑒了此格式。
5、multipart/form-data將表單中的每個(gè)input轉(zhuǎn)為了一個(gè)由boundary分割的小格式,沒有轉(zhuǎn)碼,直接將utf8字節(jié)拼接到請求體中,在本地有多少字節(jié)實(shí)際就發(fā)送多少字節(jié),極大提高了效率,適合傳輸長字節(jié)。
3、raw
可以上傳任意格式的文本,可以上傳text、json、xml、html等

http的傳輸格式:

4、binary
相當(dāng)于Content-Type:application/octet-stream,從字面意思得知,只可以上傳二進(jìn)制數(shù)據(jù),通常用來上傳文件,由于沒有鍵值,所以,一次只能上傳一個(gè)文件。

postman中也可以看出,下面只有一個(gè)select file的功能。也說明只能傳文件。

輔助
postman有個(gè)很好用的功能預(yù)覽代碼,點(diǎn)擊右側(cè)code,選擇格式

有多種格式,尤其是對于各種語言的功能,比如像Go語言,直接生成代碼,簡直太6了。大家也可以親自看一下。代碼簡直是可以直接拿過去用了。

參考:
1、postman中 form-data、x-www-form-urlencoded、raw、binary的區(qū)別
2、post使用form-data和x-www-form-urlencoded的本質(zhì)區(qū)別