HTTP基本概念
- HTTP是Hyper Text Transfer Protocol(超文本傳輸協議)的縮寫。
- HTTP是一個應用層協議,由請求和響應構成,是一個標準的客戶端服務器模型。
- HTTP是一個無狀態的協議。
在TCP/IP協議棧中的位置
HTTP協議通常承載于TCP協議之上,有時也承載于TLS或SSL協議層之上,這個時候,就成了我們常說的HTTPS。如下圖所示:
默認HTTP的端口號為80,HTTPS的端口號為443。
HTTP的請求響應模型
HTTP協議永遠都是客戶端發起請求,服務器回送響應。見下圖:
這樣就限制了使用HTTP協議,無法實現在客戶端沒有發起請求的時候,服務器將消息推送給客戶端。HTML5定義了WebSocket協議,它實現了瀏覽器與服務器全雙工通信(full-duplex),可以借助它實現服務器向客戶端推送消息。
HTTP工作流程
一次HTTP操作稱為一個事務,其工作過程可分為四步:
- 首先客戶機與服務器需要建立連接。只要單擊某個超級鏈接,HTTP的工作開始。
- 建立連接后,客戶機發送一個請求給服務器,請求方式的格式為:統一資源標識符(URL)、協議版本號,后邊是MIME信息包括請求修飾符、客戶機信息和可能的內容。
- 服務器接到請求后,給予相應的響應信息,其格式為一個狀態行,包括信息的協議版本號、一個成功或錯誤的代碼,后邊是MIME信息包括服務器信息、實體信息和可能的內容。
- 客戶端接收服務器所返回的信息通過瀏覽器顯示在用戶的顯示屏上,然后客戶機與服務器斷開連接。
如果在以上過程中的某一步出現錯誤,那么產生錯誤的信息將返回到客戶端,有顯示屏輸出。對于用戶來說,這些過程是由HTTP自己完成的,用戶只要用鼠標點擊,等待信息顯示就可以了。
方法
HTTP支持幾種不同的的請求命令,成為 HTTP方法。每一個請求報文中都包含一個方法,告訴服務器執行什么動作。
常見http方法 | 描述 |
---|---|
GET | 向特定的資源發出請求,獲取指定資源 |
POST | 發送客戶端數據到服務器(如表單提交) |
DELETE | 從服務器刪除指定資源 |
PUT | 向服務器指定資源上傳最新數據(完整替換數據) |
PATCH | 向服務器指定資源上傳最新數據(局部更新數據) |
此外,還有head
,trace
,options
等。
狀態碼
當服務器收到請求,返回的響應報文中會帶有一個3位數字的狀態碼,告訴客戶端請求是否成功。狀態碼分5類:
整體范圍 | 已定義范圍 | 描述 |
---|---|---|
100-199 | 100-101 | 信息提示 |
200-299 | 200-206 | 成功 |
300-399 | 300-305 | 重定向 |
400-499 | 400-415 | 客戶端錯誤 |
500-599 | 500-505 | 服務器錯誤 |
常見的狀態:200
表示成功; 302
表示重定向;404
表示找不到資源。
HTTP報文
報文是具有固定格式的數據塊,由3部分組成:
- 對報文進行描述的起始行(start line)
- 包含屬性的首部塊(header)
- 可選的,包含數據的主體部分(body)
請求報文格式
<method> <request-URL> <version>
<headers>
<entity-body>
響應報文格式
<version> <status> <reason-phrase>
<headers>
<entity-body>
只有起始行不同,主體是可選的。下圖是一個報文例子:
Content-Type 字段
頭信息必須是 ASCII 碼,后面的數據可以是任何格式。因此,服務器回應的時候,必須告訴客戶端,數據是什么格式,所以有了Content-Type
這個字段。
常見的類型:
- text/plain
- text/html
- text/css
- image/jpeg
- image/png
- video/mp4
- audio/mp4
- application/javascript
- application/json
這些數據類型總稱為MIME type
,每個值包括一級類型和二級類型,之間用斜杠分隔。
除了預定義的類型,廠商也可以自定義類型:
application/vnd.debian.binary-package
上面的類型表明,發送的是Debian系統的二進制數據包。
MIME type還可以在尾部使用分號,添加參數。
Content-Type: text/html; charset=utf-8
上面的類型表明,發送的是網頁,而且編碼是UTF-8。
客戶端請求的時候,可以使用Accept字段聲明自己可以接受哪些數據格式。
Accept: /
上面代碼中,客戶端聲明自己可以接受任何格式的數據。
MIME type不僅用在HTTP協議,還可以用在其他地方,比如HTML網頁。
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<!-- 等同于 -->
<meta charset="utf-8" />
Content-Encoding 字段
由于發送的數據可以是任何格式,因此可以把數據壓縮后再發送。Content-Encoding字段說明數據的壓縮方法。
- Content-Encoding: gzip
- Content-Encoding: compress
- Content-Encoding: deflate
客戶端在請求時,用Accept-Encoding字段說明自己可以接受哪些壓縮方法。
Accept-Encoding: gzip, deflate
參考資料:
《HTTP權威指南》
阮一峰-http入門