聊聊 HTTP 常见的请求方式
在互聯網已經滲透了生產、生活各個角落的今天,人們可以登錄微信語音聊天,可以隨手“掃”到各種功能的二維碼,可以通過方便快捷的無人超市購物……這種互聯網領域的跨越式發展,不僅滿足了人們生活中各種各樣的需求,也催生了一個個新興領域的誕生,為經濟增長注入了強勁動力。
上網的過程,其實是瀏覽器向服務端發送請求,之后將服務端主機上的內容顯示到本地的一個流程。而瀏覽器與服務器之間的請求走的就是 HTTP 協議。
自 1990 年以來,超文本傳輸協議(HTTP) 就成為了互聯網數據通信的基礎,它是分布式協作超媒體信息系統的應用層協議,是一種通用的無狀態協議。具體來講就是讓服務器不保留與客戶交易時的任何狀態,由客戶端單方面向服務器發送請求數據。
HTTP 主要有 0.9、1.0、1.1、2.0 版本,其中 1.1 版本定義了 9 種 Method(方法),分別是:
這些方法中,最常見的便是 GET 和 POST,但是可能很少有人關注兩者都有什么作用,我們一起來看一看吧。
GET vs POST Method
GET 和 POST 都是 HTTP 協定的一種請求標準,同樣基于 TCP 傳輸層協議。兩者主要區別在存放數據的方式不同,進而造成的傳輸量、安全性等差異。
GET
我們先來看一下 GET 是怎么傳送信息的:
<form method="get" action=""> <input type="text" name="id" /> <input type="submit" /> </form>如上完成代碼點擊“提交”之后,瀏覽器的網址就會變成 http://www.a.com/a.html?id=11111,瀏覽器會自動將表單內容轉為 Query String 加在 URL 后面進行請求。這樣,從瀏覽器的網址里就可以看見表單要傳送的資料。
POST
接下來我們看看 POST 的傳送:
<form method="post" action=""> <input type="text" name="id" /> <input type="submit" /> </form>提交之后,地址并無變化,但是通過查看 HTTP Request 的內容可以發現,POST 是將表單資料放在 Message Body 進行傳送。
看不太懂代碼的小伙伴也不要著急,我們以現實生活中寄信的機制來舉例。如果說信封的撰寫格式是 HTTP,我們可以將信封外的內容稱為 Http-Header,信封內的書信稱為 Message Body。 HTTP Method 就是你要告訴郵差的寄信規則。
而假設 GET 就如同明信片一樣將要傳遞的信息寫在信封(Http-Header)上,是信封內不裝信件的寄送方式,是直接將要傳送的信息以 Query String(一種 Key/Vaule 的編碼方式)的形式加在地址(URL)后面進行傳送。那 POST 就是信封內裝有信件的寄送方式,不但信封可以寫東西,信封內(Message Body)還可以放入你想要寄送的其他資料,之后由郵差進行傳送。
GET VS POST
總體來說,兩種請求方式有如下區別:
**- 傳遞參數方式:**GET 是將參數寫在 URL 中 ? 的后面,并用 & 分隔不同參數;而 POST 是將信息存放在 Message Body 中傳送。
**- 傳輸資料量限制:**HTTP 協定本身沒有限制 URL 及正文長度,多半是瀏覽器為了避免過長的 URL 消耗過多的資源而限制長度;而以 POST 請求通常都沒有內容長度限制的問題。
**- 安全性問題:**GET 請求方式從瀏覽器的 URL 地址就可以看到參數;但無論是 GET 還是 POST 其實都是不安全的,因為 HTTP 協定是明文傳輸,只要攔截封包便能輕易獲取重要資訊。想要安全傳輸資料,必須使用 SSL/TLS來加密封包,也就是 HTTPS。
除了我們較為常見的 GET 和 POST 兩種請求方式,現在其他請求方式也越來越多的被使用。例如又拍云基于 RESTful 架構的 REST API 中,除了使用 GET 獲取文件外,也會使用 PUT 來上傳文件,DELETE 用來刪除文件,HEAD 用來獲取文件信息,使用 PATCH 來修改文件 Metadata 信息等等。
請求與狀態碼
當然,上面講的請求方式雖然很常見,但是如果不是稍微有些了解或者對互聯網有些關注的小伙伴,可能并不會注意到。但是我們接下來說的肯定是大家都有見過的。畢竟在我們使用網頁瀏覽內容的過程中肯定,有見到過例如:404 NOT FOUND、504 TIME OUT,這類的提示。其實這個是 HTTP 的狀態碼。
HTTP 狀態碼由三個十進制數字組成,第一個十進制數字定義了狀態碼的類型,后兩位不具有任何分類作用。當用戶訪問一個網頁時,用戶的瀏覽器會向網頁所在服務器發出請求。在瀏覽器接收并顯示網頁前,此網頁所在的服務器會返回一個包含 HTTP 狀態碼的信息頭(Header)用以響應瀏覽器的請求。而這個狀態碼則可以幫助我們粗略的判斷請求結果或錯誤原因。
HTTP 狀態碼共分為 5 種類型:
一直在使用又拍云 CDN 的小伙伴兒對一些常見的狀態碼肯定很熟悉。比如,網站訪問成功請求會返回 200;開啟了強制 HTTPS,會返回 301;如果開啟了防盜鏈被攔截,則是返回 403 等等。
在這些常規的狀態碼下,又拍云還進行了進一步的封裝,讓我們可以通過查詢又拍云錯誤碼表的方式獲得更為準確的網站報錯原因。
{“code”:“40310013”,“msg”:“invalid user token.”}
查詢錯誤碼表得知,觸發了 Token 防盜鏈規
講了這么多,是不是對 HTTP 請求有了更近一步的了解?當然了,HTTP 協議不僅僅于此,有興趣的小伙伴兒們要持續關注哦~
總結
以上是生活随笔為你收集整理的聊聊 HTTP 常见的请求方式的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 云原生网络代理(MOSN)的进化之路
- 下一篇: 高性能、低成本的高防 IP 产品能现实吗