GET和POST報(bào)文上的區(qū)別
前 言
最近看了一些同學(xué)的面經(jīng),發(fā)現(xiàn)無(wú)論什么技術(shù)崗位,還是會(huì)問(wèn)到 GET 和 POST 請(qǐng)求的區(qū)別,而搜索出來(lái)的答案并不能讓我們裝得一手好逼,那就讓我們從 HTTP 報(bào)文的角度來(lái)擼一波,從而搞明白他們的區(qū)別。
標(biāo)準(zhǔn)答案
在開(kāi)始之前,先看一下標(biāo)準(zhǔn)答案【來(lái)自w3school】長(zhǎng)什么樣子來(lái)保個(gè)底。標(biāo)準(zhǔn)答案很美好,但是在面試的時(shí)候把下面的表格甩面試官一臉,問(wèn)題應(yīng)該也不大。
注意,并不是說(shuō)標(biāo)準(zhǔn)答案有誤,上述區(qū)別在大部分瀏覽器上是存在的,因?yàn)檫@些瀏覽器實(shí)現(xiàn)了 HTTP 標(biāo)準(zhǔn)。
所以從標(biāo)準(zhǔn)上來(lái)看,GET 和 POST 的區(qū)別基本上可以總結(jié)如下:
GET 用于獲取信息,無(wú)副作用,冪等,且可緩存
POST 用于修改服務(wù)器上的數(shù)據(jù),有副作用,非冪等,不可緩存
但是,既然本文從報(bào)文角度來(lái)說(shuō),那就先不討論 RFC 上的區(qū)別,單純從數(shù)據(jù)角度談?wù)劇?/p>
GET和POST報(bào)文上的區(qū)別
先下結(jié)論:GET 和 POST 方法沒(méi)有本質(zhì)區(qū)別,僅報(bào)文格式不同。
GET 和 POST 只是 HTTP 協(xié)議中兩種請(qǐng)求方式,而 HTTP 協(xié)議是基于 TCP/IP 的應(yīng)用層協(xié)議,無(wú)論 GET 還是 POST,用的都是同一個(gè)傳輸層協(xié)議,所以在傳輸上,沒(méi)有區(qū)別。
報(bào)文格式上,不帶參數(shù)時(shí),最大區(qū)別僅僅是第一行方法名不同,一個(gè)是GET,一個(gè)是POST
帶參數(shù)時(shí)報(bào)文的區(qū)別呢?在約定中,GET 方法的參數(shù)應(yīng)該放在 url 中,POST 方法參數(shù)應(yīng)該放在 body 中
舉個(gè)例子,如果參數(shù)是 name=qiming.c, age=22。
GET 方法簡(jiǎn)約版報(bào)文可能是這樣的
Host: localhost
POST 方法簡(jiǎn)約版報(bào)文可能是這樣的
兩種方法本質(zhì)上是 TCP 連接,沒(méi)有差別,也就是說(shuō),如果我不按規(guī)范來(lái)也是可以的。我們可以在 URL 上寫(xiě)參數(shù),然后方法使用 POST;也可以在 Body 寫(xiě)參數(shù),然后方法使用 GET。當(dāng)然,這需要服務(wù)端支持。
常見(jiàn)的疑惑問(wèn)題
一、GET 方法參數(shù)寫(xiě)法是固定的嗎?
在約定中,一般我們的參數(shù)是寫(xiě)在 ? 后面,用 & 分割。
我們知道,解析報(bào)文的過(guò)程是通過(guò)獲取 TCP 數(shù)據(jù),用正則等工具從數(shù)據(jù)中獲取 Header 和 Body,從而提取參數(shù)。
也就是說(shuō),我們可以自己約定參數(shù)的寫(xiě)法,只要服務(wù)端能夠解釋出來(lái)就行,一種比較流行的寫(xiě)法是這樣 :
二、POST 方法比 GET 方法安全?
按照網(wǎng)上大部分文章的解釋,POST 比 GET 安全,因?yàn)閿?shù)據(jù)在地址欄上不可見(jiàn)。
然而從傳輸?shù)慕嵌葋?lái)說(shuō),他們都是不安全的,因?yàn)?HTTP 在網(wǎng)絡(luò)上是明文傳輸,只要在網(wǎng)絡(luò)節(jié)點(diǎn)上抓包,就能完整地獲取數(shù)據(jù)報(bào)文。
要想安全傳輸,就只有加密,也就是 HTTPS。
三、聽(tīng)說(shuō) GET 方法參數(shù)長(zhǎng)度有限制?
在網(wǎng)上看到很多關(guān)于兩者區(qū)別的文章都有這一條,提到瀏覽器地址欄輸入的參數(shù)是有限的。
首先說(shuō)明一點(diǎn),其實(shí)HTTP 協(xié)議本身倒并沒(méi)有 Body 和 URL 的長(zhǎng)度限制,對(duì) URL 限制的大多是瀏覽器和服務(wù)器端自己限制的。
瀏覽器原因就不說(shuō)了,服務(wù)器是因?yàn)樘幚黹L(zhǎng) URL 要消耗比較多的資源,為了性能和安全(防止惡意構(gòu)造長(zhǎng) URL 來(lái)攻擊)考慮,會(huì)給 URL 長(zhǎng)度加限制。
四、POST 方法會(huì)產(chǎn)生兩個(gè)TCP數(shù)據(jù)包?
有些文章中提到,POST 請(qǐng)求會(huì)將 Header 和 Body 分開(kāi)發(fā)送,先發(fā)送 Header,服務(wù)端返回 100 狀態(tài)碼再發(fā)送 Body。
HTTP 協(xié)議中也并沒(méi)有明確說(shuō)明 POST 會(huì)產(chǎn)生兩個(gè) TCP 數(shù)據(jù)包,而且實(shí)際測(cè)試(Chrome)發(fā)現(xiàn),Header 和 Body 不會(huì)分開(kāi)發(fā)送。
所以,Header 和 Body 分開(kāi)發(fā)送是部分瀏覽器或框架的請(qǐng)求方法,不屬于 Post的必然行為。
代碼驗(yàn)證時(shí)間
如果對(duì) GET 和 POST 請(qǐng)求的報(bào)文區(qū)別有疑惑,可以直接用Python起一個(gè) Socket 服務(wù)端,然后封裝簡(jiǎn)單的 HTTP 處理方法,直接觀察和處理 HTTP 報(bào)文,就能一目了然。多實(shí)驗(yàn)還是有好處的。
上面代碼就是用Python寫(xiě)的簡(jiǎn)單的打印請(qǐng)求報(bào)文然后返回 Hello World 的 html 頁(yè)面,接著運(yùn)行起來(lái):
然后從瀏覽器中來(lái)請(qǐng)求看看
打印出來(lái)的報(bào)文
然后就可以手動(dòng)驗(yàn)證上面的一些說(shuō)法,比如說(shuō)要測(cè)試 Header 和 Body 是否分開(kāi)傳輸,由于代碼沒(méi)有返回 100 狀態(tài)碼,如果我們 POST 請(qǐng)求成功就說(shuō)明是一起傳輸?shù)?(Chrome/postman)。
又比如 w3school 里面說(shuō) URL 的最大長(zhǎng)度是 2048 個(gè)字符,那我們?cè)诖a里面加上一句計(jì)算uri 長(zhǎng)度的代碼即可
我們用 Postman 直接發(fā)送 >2048 個(gè)字符(比如這里發(fā)送2800個(gè)字符)的請(qǐng)求看看:
很明顯可以看到發(fā)2800個(gè)字符也都是沒(méi)問(wèn)題的!
然后我們可以得出結(jié)論,url 長(zhǎng)度限制僅僅是某些瀏覽器和服務(wù)器的限制,和 HTTP 協(xié)議本身并沒(méi)有關(guān)系。
所以有什么想法用Python寫(xiě)個(gè)小腳本驗(yàn)證一下就徹底明白了!
原文標(biāo)題 : 面試必考 | GET和POST區(qū)別

發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
最新活動(dòng)更多
-
6月20日立即下載>> 【白皮書(shū)】精準(zhǔn)測(cè)量 安全高效——福祿克光伏行業(yè)解決方案
-
7月3日立即報(bào)名>> 【在線會(huì)議】英飛凌新一代智能照明方案賦能綠色建筑與工業(yè)互聯(lián)
-
7月22-29日立即報(bào)名>> 【線下論壇】第三屆安富利汽車(chē)生態(tài)圈峰會(huì)
-
7.30-8.1火熱報(bào)名中>> 全數(shù)會(huì)2025(第六屆)機(jī)器人及智能工廠展
-
7月31日免費(fèi)預(yù)約>> OFweek 2025具身機(jī)器人動(dòng)力電池技術(shù)應(yīng)用大會(huì)
-
免費(fèi)參會(huì)立即報(bào)名>> 7月30日- 8月1日 2025全數(shù)會(huì)工業(yè)芯片與傳感儀表展
推薦專題
- 1 AI 眼鏡讓百萬(wàn) APP「集體失業(yè)」?
- 2 大廠紛紛入局,百度、阿里、字節(jié)搶奪Agent話語(yǔ)權(quán)
- 3 深度報(bào)告|中國(guó)AI產(chǎn)業(yè)正在崛起成全球力量,市場(chǎng)潛力和關(guān)鍵挑戰(zhàn)有哪些?
- 4 上海跑出80億超級(jí)獨(dú)角獸:獲上市公司戰(zhàn)投,干人形機(jī)器人
- 5 國(guó)家數(shù)據(jù)局局長(zhǎng)劉烈宏調(diào)研格創(chuàng)東智
- 6 一文看懂視覺(jué)語(yǔ)言動(dòng)作模型(VLA)及其應(yīng)用
- 7 下一代入口之戰(zhàn):大廠為何紛紛押注智能體?
- 8 百億AI芯片訂單,瘋狂傾銷(xiāo)中東?
- 9 Robotaxi新消息密集釋放,量產(chǎn)元年誰(shuí)在領(lǐng)跑?
- 10 格斗大賽出圈!人形機(jī)器人致命短板曝光:頭腦過(guò)于簡(jiǎn)單