盤點(diǎn)GET 和 POST請(qǐng)求的本質(zhì)區(qū)別
?GET和POST的本質(zhì)區(qū)別在于設(shè)計(jì)目的和語(yǔ)義?:GET用于獲取資源(冪等、安全),POST用于更新資源(非冪等、可能改變服務(wù)器狀態(tài))。以下是具體差異:
數(shù)據(jù)傳輸方式
GET:參數(shù)通過URL的查詢字符串傳遞(如?key=value),可見且有限制 。 ?
POST:參數(shù)通過請(qǐng)求體(Body)傳遞,不暴露在URL中 。 ?
安全性
GET:參數(shù)暴露在URL中,不適合傳輸敏感信息 。 ?
POST:參數(shù)隱藏在請(qǐng)求體中,相對(duì)更安全(但需配合HTTPS加密) 。 ?
冪等性
GET:多次請(qǐng)求相同URL結(jié)果一致(冪等),不改變服務(wù)器狀態(tài) 。 ?
POST:多次請(qǐng)求可能產(chǎn)生不同結(jié)果(非冪等),通常用于創(chuàng)建或更新資源 。 ?
緩存與歷史記錄
GET:可被緩存,URL會(huì)保留在瀏覽器歷史中 。 ?
POST:通常不被緩存,參數(shù)不會(huì)保留在歷史記錄中 。 ?
使用場(chǎng)景
GET:適用于查詢、檢索等無副作用的操作(如頁(yè)面訪問) 。 ?
POST:適用于表單提交、文件上傳等需修改服務(wù)器狀態(tài)的操作 。 ?
GET和POST是 HTTP 協(xié)議中常用的兩種請(qǐng)求方法,它們之間的區(qū)別如下:
1. 數(shù)據(jù)傳輸方式
GET:通過 URL 傳遞數(shù)據(jù),數(shù)據(jù)在 URL 中可見,以鍵值對(duì)的形式出現(xiàn)在 URL 中,通過?分隔 URL 和參數(shù),通過&分隔參數(shù)。
POST:通過 HTTP 請(qǐng)求的 body 傳遞數(shù)據(jù),數(shù)據(jù)不會(huì)出現(xiàn)在 URL 中,而是作為請(qǐng)求的一部分進(jìn)行發(fā)送。
2. 數(shù)據(jù)傳輸大小
GET:由于數(shù)據(jù)在 URL 中傳遞,所以傳輸?shù)臄?shù)據(jù)量有限制,一般在 2KB 到 8KB 之間,不同瀏覽器有不同的限制。
POST:由于數(shù)據(jù)作為請(qǐng)求的一部分,所以傳輸?shù)臄?shù)據(jù)量相對(duì)較大,一般沒有大小限制。
3. 安全性
GET:因?yàn)閿?shù)據(jù)在 URL 中可見,所以不適合傳輸敏感信息,如密碼等。
POST:因?yàn)閿?shù)據(jù)不會(huì)出現(xiàn)在 URL 中,所以相對(duì)更安全,適合傳輸敏感信息。
4. 緩存
GET:可以被瀏覽器緩存,會(huì)留下歷史記錄。
POST:不會(huì)被瀏覽器緩存,不會(huì)留下歷史記錄。
5. 冪等性
GET:冪等,即對(duì)同一 URL 的多次請(qǐng)求會(huì)返回相同的結(jié)果。
POST:不冪等,即對(duì)同一 URL 的多次請(qǐng)求可能會(huì)返回不同的結(jié)果。
綜上所述,GET 和 POST 在數(shù)據(jù)傳輸方式、傳輸大小、安全性、緩存和冪等性等方面有所不同,開發(fā)者需要根據(jù)具體的需求來選擇合適的請(qǐng)求方法。
一、原理區(qū)別
一般我們?cè)跒g覽器輸入一個(gè)網(wǎng)址訪問網(wǎng)站都是GET請(qǐng)求;再FORM表單中,可以通過設(shè)置Method指定提交方式為GET或者POST提交方式,默認(rèn)為GET提交方式。
HTTP定義了與服務(wù)器交互的不同方法,其中最基本的四種:GET,POST,PUT,DELETE,HEAD,其中GET和HEAD被稱為安全方法,因?yàn)槭褂肎ET和HEAD的HTTP請(qǐng)求不會(huì)產(chǎn)生什么動(dòng)作。不會(huì)產(chǎn)生動(dòng)作意味著GET和HEAD的HTTP請(qǐng)求不會(huì)在服務(wù)器上產(chǎn)生任何結(jié)果。但是安全方法并不是什么動(dòng)作都不產(chǎn)生,這里的安全方法僅僅指不會(huì)修改信息。
根據(jù)HTTP規(guī)范,POST可能會(huì)修改服務(wù)器上的資源的請(qǐng)求。比如知乎編寫文章,用戶提交一篇文章或者一個(gè)讀者提交評(píng)論是通過POST請(qǐng)求來實(shí)現(xiàn)的,因?yàn)樵偬峤晃恼禄蛘咴u(píng)論提交后資源(即某個(gè)頁(yè)面)不同了,或者說資源被修改了,這些便是“不安全方法”。
二、使用時(shí)最直觀的區(qū)別
最直觀的區(qū)別就是GET把參數(shù)包含在URL中,POST通過request body傳遞參數(shù)。
三、為什么get比post更快
1.post請(qǐng)求包含更多的請(qǐng)求頭
因?yàn)閜ost需要在請(qǐng)求的body部分包含數(shù)據(jù),所以會(huì)多了幾個(gè)數(shù)據(jù)描述部分的首部字段(如:content-type),這其實(shí)是微乎其微的。
2.最重要的一條,post在真正接收數(shù)據(jù)之前會(huì)先將請(qǐng)求頭發(fā)送給服務(wù)器進(jìn)行確認(rèn),然后才真正發(fā)送數(shù)據(jù)
post請(qǐng)求的過程:(1)瀏覽器請(qǐng)求tcp連接(第一次握手)(2)服務(wù)器答應(yīng)進(jìn)行tcp連接(第二次握手)(3)瀏覽器確認(rèn),并發(fā)送post請(qǐng)求頭(第三次握手,這個(gè)報(bào)文比較小,所以http會(huì)在此時(shí)進(jìn)行第一次數(shù)據(jù)發(fā)送)(4)服務(wù)器返回100 Continue響應(yīng)(5)瀏覽器發(fā)送數(shù)據(jù)(6)服務(wù)器返回200 OK響應(yīng) get請(qǐng)求的過程:(1)瀏覽器請(qǐng)求tcp連接(第一次握手)(2)服務(wù)器答應(yīng)進(jìn)行tcp連接(第二次握手)(3)瀏覽器確認(rèn),并發(fā)送get請(qǐng)求頭和數(shù)據(jù)(第三次握手,這個(gè)報(bào)文比較小,所以http會(huì)在此時(shí)進(jìn)行第一次數(shù)據(jù)發(fā)送)(4)服務(wù)器返回200 OK響應(yīng)也就是說,目測(cè)get的總耗是post的2/3左右,這個(gè)口說無憑,網(wǎng)上已經(jīng)有網(wǎng)友進(jìn)行過測(cè)試。
3.get會(huì)將數(shù)據(jù)緩存起來,而post不會(huì)
可以做個(gè)簡(jiǎn)短的測(cè)試,使用ajax采用get方式請(qǐng)求靜態(tài)數(shù)據(jù)(比如html頁(yè)面,圖片)的時(shí)候,如果兩次傳輸?shù)臄?shù)據(jù)相同,第二次以后消耗的時(shí)間將會(huì)在10ms以內(nèi)(chrome測(cè)試),而post每次消耗的時(shí)間都差不多。經(jīng)測(cè)試,chrome和firefox下如果檢測(cè)到get請(qǐng)求的是靜態(tài)資源,則會(huì)緩存,如果是數(shù)據(jù),則不會(huì)緩存,但是IE什么都會(huì)緩存起來,當(dāng)然,應(yīng)該沒有人用post去獲取靜態(tài)數(shù)據(jù)吧,反正我是沒見過。
四、面試是一般怎么回答get和post的區(qū)別
(1)post更安全(不會(huì)作為url的一部分,不會(huì)被緩存、保存在服務(wù)器日志、以及瀏覽器瀏覽記錄中)
(2)post發(fā)送的數(shù)據(jù)更大(get有url長(zhǎng)度限制)
(3)post能發(fā)送更多的數(shù)據(jù)類型(get只能發(fā)送ASCII字符)
(4)post比get慢
(5)post用于修改和寫入數(shù)據(jù),get一般用于搜索排序和篩選之類的操作(淘寶,支付寶的搜索查詢都是get提交),目的是資源的獲取,讀取數(shù)據(jù)
五、測(cè)試get和post請(qǐng)求的工具
get和post請(qǐng)求一般使用的是接口測(cè)試工具,接口測(cè)試工具我個(gè)人一般使用的是:apipost和jmeter。
apipost是一款國(guó)產(chǎn)的接口測(cè)試工具和接口文檔生成工具,能夠滿足我們?nèi)粘9ぷ鳟?dāng)中對(duì)于接口測(cè)試和接口文檔生成的工作需求。接口文檔還可以支持多種格式的生成,有在線版、markdown、word版等多種格式的接口文檔。
HTTP請(qǐng)求簡(jiǎn)述
在開始講解GET和POST之前,我們先來了解一下HTTP請(qǐng)求的基本概念。
HTTP(HyperText Transfer Protocol)是用于傳輸超文本的數(shù)據(jù)通信協(xié)議,是萬維網(wǎng)的基礎(chǔ)協(xié)議。它定義了客戶端和服務(wù)器之間的交互方式,包括請(qǐng)求方法、狀態(tài)碼、請(qǐng)求頭、響應(yīng)頭等。
請(qǐng)求方法
HTTP請(qǐng)求方法是用來指定對(duì)資源進(jìn)行操作的指令,主要有以下幾種:
GET:請(qǐng)求數(shù)據(jù)的讀取操作,常用于獲取網(wǎng)頁(yè)內(nèi)容。
POST:提交數(shù)據(jù)給服務(wù)器,通常用于提交表單或上傳文件。
PUT:用于更新指定的資源。
DELETE:刪除指定的資源。
HEAD:獲取響應(yīng)頭部信息,不返回實(shí)體內(nèi)容。
OPTIONS:獲取服務(wù)器支持的請(qǐng)求方法。
PATCH:對(duì)資源進(jìn)行部分更新。
今天,我們重點(diǎn)講解GET和POST。
GET請(qǐng)求
GET請(qǐng)求是最常用的請(qǐng)求方式之一,它用于從服務(wù)器獲取資源。GET請(qǐng)求的數(shù)據(jù)會(huì)附在URL的查詢字符串中,格式為key=value,多個(gè)參數(shù)之間用&連接。
1. 特點(diǎn)
數(shù)據(jù)可見:請(qǐng)求參數(shù)會(huì)顯示在URL中,容易被用戶看到。
長(zhǎng)度限制:URL長(zhǎng)度有限制,瀏覽器和服務(wù)器一般對(duì)URL長(zhǎng)度有限制,常見限制為2048字符。
緩存支持:GET請(qǐng)求可以被緩存,適合用來獲取靜態(tài)資源,如圖片、CSS文件等。
冪等性:GET請(qǐng)求是冪等的,即多次請(qǐng)求的效果相同。
在這個(gè)請(qǐng)求中,/index.html 是請(qǐng)求的資源路徑,name=tom&age=18 是查詢字符串。
POST請(qǐng)求
POST請(qǐng)求用于向服務(wù)器提交數(shù)據(jù),常用于表單提交和文件上傳。POST請(qǐng)求的數(shù)據(jù)會(huì)放在請(qǐng)求體中,不會(huì)顯示在URL中。
1. 特點(diǎn)
數(shù)據(jù)隱藏:請(qǐng)求參數(shù)放在請(qǐng)求體中,不會(huì)顯示在URL中,安全性較高。
無長(zhǎng)度限制:POST請(qǐng)求的參數(shù)長(zhǎng)度較長(zhǎng),不受URL長(zhǎng)度限制。
不緩存:POST請(qǐng)求不支持緩存,適合用于提交動(dòng)態(tài)數(shù)據(jù)。
非冪等性:POST請(qǐng)求一般是非冪等的,多次提交可能會(huì)產(chǎn)生不同的效果。
2. 示例
下面是一個(gè)典型的POST請(qǐng)求示例:
在這個(gè)請(qǐng)求中,/submit 是請(qǐng)求的資源路徑,Content-Type 指定了數(shù)據(jù)的格式,name=tom&age=18 是請(qǐng)求體中的數(shù)據(jù)。
GET和POST的區(qū)別
通過上面的介紹,我們可以總結(jié)出GET和POST的主要區(qū)別:
1. 數(shù)據(jù)傳輸方式
GET:數(shù)據(jù)通過URL傳遞,數(shù)據(jù)以 key=value 的形式拼接在URL后面。
POST:數(shù)據(jù)通過請(qǐng)求體傳遞,可以包含大量數(shù)據(jù),格式靈活。
2. 安全性
GET:數(shù)據(jù)明文傳輸,容易被截取和篡改,適合傳輸少量不敏感數(shù)據(jù)。
POST:數(shù)據(jù)在請(qǐng)求體中傳輸,安全性較高,適合傳輸敏感數(shù)據(jù)。
3. 數(shù)據(jù)長(zhǎng)度限制
GET:URL長(zhǎng)度有限制,一般為2048字符。
POST:請(qǐng)求體數(shù)據(jù)長(zhǎng)度不受限制,可以傳輸大量數(shù)據(jù)。
4. 緩存和冪等性
GET:支持緩存,且請(qǐng)求是冪等的。
POST:不支持緩存,且請(qǐng)求通常是非冪等的。
應(yīng)用場(chǎng)景
1. 使用GET的場(chǎng)景
獲取數(shù)據(jù),如加載網(wǎng)頁(yè)、查詢信息。
請(qǐng)求簡(jiǎn)單的靜態(tài)資源,如圖片、CSS、JavaScript文件。
URL參數(shù)較少且不涉及敏感數(shù)據(jù)。
2. 使用POST的場(chǎng)景
提交表單數(shù)據(jù),如用戶登錄、注冊(cè)信息。
上傳文件,如圖片、文檔等。
傳輸大量數(shù)據(jù)或復(fù)雜的數(shù)據(jù)結(jié)構(gòu)。





