瞭解 HTTP 這篇文章就夠了

目錄


HTTP介紹

HTTP協議是Hyper Text Transfer Protocol(超文本傳輸協議)的縮寫,是用於從萬維網(WWW:World Wide Web )服務器傳輸超文本到本地瀏覽器的傳送協議。。

HTTP是基於TCP/IP通信協議來傳遞數據(HTML 文件, 圖片文件, 查詢結果等)的。

HTTP 工作原理

HTTP協議工作於客戶端-服務端架構上。瀏覽器作爲HTTP客戶端通過URL向HTTP服務端即WEB服務器發送所有請求。

Web服務器有:Apache服務器,IIS服務器(Internet Information Services)等。

Web服務器根據接收到的請求後,向客戶端發送響應信息。

HTTP默認端口號爲80,但是你也可以改爲8080或者其他端口。

HTTP三點注意事項:

  • HTTP是無連接:無連接的含義是限制每次連接只處理一個請求。服務器處理完客戶的請求,並收到客戶的應答後,即斷開連接。採用這種方式可以節省傳輸時間。
  • HTTP是媒體獨立的:這意味着,只要客戶端和服務器知道如何處理的數據內容,任何類型的數據都可以通過HTTP發送。客戶端以及服務器指定使用適合的MIME-type內容類型。
  • HTTP是無狀態:HTTP協議是無狀態協議。無狀態是指協議對於事務處理沒有記憶能力。缺少狀態意味着如果後續處理需要前面的信息,則它必須重傳,這樣可能導致每次連接傳送的數據量增大。另一方面,在服務器不需要先前信息時它的應答就較快。

以下圖表展示了HTTP協議通信流程:

在這裏插入圖片描述


HTTP 消息結構

HTTP是基於客戶端/服務端(C/S)的架構模型,通過一個可靠的鏈接來交換信息,是一個無狀態的請求/響應協議。

一個HTTP"客戶端"是一個應用程序(Web瀏覽器或其他任何客戶端),通過連接到服務器達到向服務器發送一個或多個HTTP的請求的目的。

一個HTTP"服務器"同樣也是一個應用程序(通常是一個Web服務,如Apache Web服務器或IIS服務器等),通過接收客戶端的請求並向客戶端發送HTTP響應數據。

HTTP使用統一資源標識符(Uniform Resource Identifiers, URI)來傳輸數據和建立連接。

一旦建立連接後,數據消息就通過類似Internet郵件所使用的格式[RFC5322]和多用途Internet郵件擴展(MIME)[RFC2045]來傳送。

HTTP響應也由四個部分組成,分別是:狀態行、消息報頭、空行和響應正文,下面是一個HTTP響應示例

在這裏插入圖片描述


HTTP 請求方式

🍥 HTTP1.0 定義了三種請求方法: GET, POST 和 HEAD方法:

GET

請求指定的頁面信息,並返回實體主體。

POST

向指定資源提交數據進行處理請求(例如提交表單或者上傳文件)。數據被包含在請求體中。POST 請求可能會導致新的資源的建立和/或已有資源的修改。

HEAD

類似於 GET 請求,只不過返回的響應中沒有具體的內容,用於獲取報頭


🍥 HTTP1.1 新增了六種請求方法:OPTIONS、PUT、PATCH、DELETE、TRACE 和 CONNECT 方法。

PUT

從客戶端向服務器傳送的數據取代指定的文檔的內容。

PATCH

是對 PUT 方法的補充,用來對已知資源進行局部更新 。

DELETE

請求服務器刪除指定的頁面。

CONNECT

HTTP/1.1 協議中預留給能夠將連接改爲管道方式的代理服務器。

OPTIONS

允許客戶端查看服務器的性能。

TRACE

回顯服務器收到的請求,主要用於測試或診斷。


HTTP狀態碼

當客戶端向服務器發送HTTP請求(post或get)時,服務器會返回一個包含HTTP狀態碼的信息頭(server header)來響應請求。

狀態碼共分爲5類,每一類分別用對應的數字開頭,下面分別介紹這5類常用的HTTP狀態碼


🍥 第一類:消息狀態碼(Informational)

該類型狀態碼錶示請求已被服務器處理,這類響應是臨時響應,只包含狀態行和某些可選的響應頭信息,並以空行結束

100:Continue

表示客戶端應當繼續發送請求。這個臨時響應是用來通知客戶端它的部分請求已經被服務器接收,且仍未被拒絕,客戶端應當繼續發送請求的剩餘部分,服務器必須在請求完成後向客戶端發送一個最終響應。

101:Switching Protocols

表示切換協議。服務器已經理解了客戶端的請求,並將通過Upgrade 消息頭通知客戶端採用不同的協議來完成這個請求。只能切換到更高級的協議,例如,切換到HTTP的新版本協議


🍥 第二類:成功狀態碼(Success)

這一類型的狀態碼,代表請求已成功被服務器接收、理解、並接受

200:OK

表示請求已成功,請求所希望的響應頭或數據體將隨此響應返回。出現此狀態碼是表示正常狀態。

201:Created

表示請求已經被實現,而且有一個新的資源已經依據請求的需要而建立,且其 URI 已經隨Location 頭信息返回。假如需要的資源無法及時建立的話,應當返回 ‘202 Accepted’。

202:Accepted

已接受。已經接受請求,但未處理完成

203:Non-Authoritative Information

非授權信息。請求成功。但返回的meta信息不在原始的服務器,而是一個副本

204:No Content

無內容。服務器成功處理,但未返回內容。在未更新網頁的情況下,可確保瀏覽器繼續顯示當前文檔

205:Reset Content

重置內容。服務器處理成功,用戶終端(例如:瀏覽器)應重置文檔視圖。可通過此返回碼清除瀏覽器的表單域

206:Partial Content

部分內容。服務器成功處理了部分GET請求,類似於 FlashGet 或者迅雷這類的 HTTP下載工具都是使用此類響應實現斷點續傳或者將一個大文檔分解爲多個下載段同時下載。


🍥 第三類:重定向狀態碼(Redirection)

這類狀態碼代表需要客戶端採取進一步的操作才能完成請求。通常,這些狀態碼用來重定向,後續的請求地址(重定向目標)在本次響應的 Location 域中指明

301:Moved Permanently

永久移動。請求的資源已被永久的移動到新URI,返回信息會包括新的URI,瀏覽器會自動定向到新URI。今後任何新的請求都應使用新的URI代替

302:Found

臨時移動。與301類似。但資源只是臨時被移動。客戶端應繼續使用原有URI

303:See Other

查看其它地址。與301類似。使用GET和POST請求查看

304:Not Modified

未修改。所請求的資源未修改,服務器返回此狀態碼時,不會返回任何資源。客戶端通常會緩存訪問過的資源,通過提供一個頭信息指出客戶端希望只返回在指定日期之後修改的資源

305:Use Proxy

使用代理。所請求的資源必須通過代理訪問

306:Unused

已經被廢棄的HTTP狀態碼

307:Temporary Redirect

臨時重定向。與302類似。使用GET請求重定向


🍥 第四類:請求錯誤狀態碼(Client Error)

這類的狀態碼代表了客戶端看起來可能發生了錯誤,妨礙了服務器的處理。除非響應的是一個 HEAD 請求,否則服務器就應該返回一個解釋當前錯誤狀況的實體,以及這是臨時的還是永久性的狀況。這些狀態碼適用於任何請求方法。瀏覽器應當向用戶顯示任何包含在此類錯誤響應中的實體內容

400:Bad Request

客戶端請求的語法錯誤,服務器無法理解

401:Unauthorized

請求要求用戶的身份認證

402:Payment Required

保留,將來使用

403:Forbidden

服務器理解請求客戶端的請求,但是拒絕執行此請求

404:Not Found

服務器無法根據客戶端的請求找到資源(網頁)。通過此代碼,網站設計人員可設置"您所請求的資源無法找到"的個性頁面

405:Method Not Allowed

客戶端請求中的方法被禁止

406:Not Acceptable

服務器無法根據客戶端請求的內容特性完成請求

407:Proxy Authentication Required

請求要求代理的身份認證,與401類似,但請求者應當使用代理進行授權

408:Request Time-out

服務器等待客戶端發送的請求時間過長,超時

409:Conflict

服務器完成客戶端的 PUT 請求時可能返回此代碼,服務器處理請求時發生了衝突

410:Gone

客戶端請求的資源已經不存在。410不同於404,如果資源以前有現在被永久刪除了可使用410代碼,網站設計人員可通過301代碼指定資源的新位置

411:Length Required

服務器無法處理客戶端發送的不帶Content-Length的請求信息

412:Precondition Failed

客戶端請求信息的先決條件錯誤

413:Request Entity Too Large

由於請求的實體過大,服務器無法處理,因此拒絕請求。爲防止客戶端的連續請求,服務器可能會關閉連接。如果只是服務器暫時無法處理,則會包含一個Retry-After的響應信息

414:Request-URI Too Large

請求的URI過長(URI通常爲網址),服務器無法處理

415:Unsupported Media Type

服務器無法處理請求附帶的媒體格式

416:Requested range not satisfiable

客戶端請求的範圍無效

417:Expectation Failed

服務器無法滿足Expect的請求頭信息


🍥 第五類:服務器錯誤狀態碼(Server Error)

這類狀態碼代表了服務器在處理請求的過程中有錯誤或者異常狀態發生,也有可能是服務器意識到以當前的軟硬件資源無法完成對請求的處理。除非這是一個HEAD 請求,否則服務器應當包含一個解釋當前錯誤狀態以及這個狀況是臨時的還是永久的解釋信息實體。瀏覽器應當向用戶展示任何在當前響應中被包含的實體

500:Internal Server Error

服務器內部錯誤,無法完成請求

501:Not Implemented

服務器不支持請求的功能,無法完成請求

502:Bad Gateway

網關錯誤。作爲網關或者代理工作的服務器嘗試執行請求時,從遠程服務器接收到了一個無效的響應

503:Service Unavailable

由於超載或系統維護,服務器暫時的無法處理客戶端的請求。延時的長度可包含在服務器的Retry-After頭信息中

504:Gateway Time-out

網關超時。充當網關或代理的服務器,未及時從遠端服務器獲取請求

505:HTTP Version not supported

服務器不支持請求的HTTP協議的版本,無法完成處理

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章