HTML 參考手冊(cè)
兩種最常用的 HTTP 方法是:GET 和 POST。
超文本傳輸協(xié)議(HTTP)的設(shè)計(jì)目的是保證客戶(hù)端與服務(wù)器之間的通信。
HTTP 的工作方式是客戶(hù)端與服務(wù)器之間的請(qǐng)求-應(yīng)答協(xié)議。
web 瀏覽器可能是客戶(hù)端,而計(jì)算機(jī)上的網(wǎng)絡(luò)應(yīng)用程序也可能作為服務(wù)器端。
舉例:客戶(hù)端(瀏覽器)向服務(wù)器提交 HTTP 請(qǐng)求;服務(wù)器向客戶(hù)端返回響應(yīng)。響應(yīng)包含關(guān)于請(qǐng)求的狀態(tài)信息以及可能被請(qǐng)求的內(nèi)容。
在客戶(hù)機(jī)和服務(wù)器之間進(jìn)行請(qǐng)求-響應(yīng)時(shí),兩種最常被用到的方法是:GET 和 POST。
請(qǐng)注意,查詢(xún)字符串(名稱(chēng)/值對(duì))是在 GET 請(qǐng)求的 URL 中發(fā)送的:
有關(guān) GET 請(qǐng)求的其他一些注釋?zhuān)?/b>
請(qǐng)注意,查詢(xún)字符串(名稱(chēng)/值對(duì))是在 POST 請(qǐng)求的 HTTP 消息主體中發(fā)送的:
有關(guān) POST 請(qǐng)求的其他一些注釋?zhuān)?/b>
下面的表格比較了兩種 HTTP 方法:GET 和 POST。
? | GET | POST |
---|---|---|
后退按鈕/刷新 | 無(wú)害 | 數(shù)據(jù)會(huì)被重新提交(瀏覽器應(yīng)該告知用戶(hù)數(shù)據(jù)會(huì)被重新提交)。 |
書(shū)簽 | 可收藏為書(shū)簽 | 不可收藏為書(shū)簽 |
緩存 | 能被緩存 | 不能緩存 |
編碼類(lèi)型 | application/x-www-form-urlencoded | application/x-www-form-urlencoded or multipart/form-data。為二進(jìn)制數(shù)據(jù)使用多重編碼。 |
歷史 | 參數(shù)保留在瀏覽器歷史中。 | 參數(shù)不會(huì)保存在瀏覽器歷史中。 |
對(duì)數(shù)據(jù)長(zhǎng)度的限制 | 是的。當(dāng)發(fā)送數(shù)據(jù)時(shí),GET 方法向 URL 添加數(shù)據(jù);URL 的長(zhǎng)度是受限制的(URL 的最大長(zhǎng)度是 2048 個(gè)字符)。 | 無(wú)限制。 |
對(duì)數(shù)據(jù)類(lèi)型的限制 | 只允許 ASCII 字符。 | 沒(méi)有限制。也允許二進(jìn)制數(shù)據(jù)。 |
安全性 | 與 POST 相比,GET 的安全性較差,因?yàn)樗l(fā)送的數(shù)據(jù)是 URL 的一部分。 在發(fā)送密碼或其他敏感信息時(shí)絕不要使用 GET ! |
POST 比 GET 更安全,因?yàn)閰?shù)不會(huì)被保存在瀏覽器歷史或 web 服務(wù)器日志中。 |
可見(jiàn)性 | 數(shù)據(jù)在 URL 中對(duì)所有人都是可見(jiàn)的。 | 數(shù)據(jù)不會(huì)顯示在 URL 中。 |
下面的表格列出了其他一些 HTTP 請(qǐng)求方法:
方法 | 描述 |
---|---|
HEAD | 與 GET 相同,但只返回 HTTP 報(bào)頭,不返回文檔主體。 |
PUT | 上傳指定的 URI 表示。 |
DELETE | 刪除指定資源。 |
OPTIONS | 返回服務(wù)器支持的 HTTP 方法。 |
CONNECT | 把請(qǐng)求連接轉(zhuǎn)換到透明的 TCP/IP 通道。 |