簡表
| 狀態碼 | 消息 | 描述 |
|---|---|---|
| 100 | Continue | 只有一部分請求被服務器接收,但只要沒被服務器拒絕,客戶端就會延續這個請求 |
| 101 | Switching Protocols | 服務器交換機協議 |
| 200 | OK | 請求被確認 |
| 201 | Created | 請求時完整的,新的資源被創建 |
| 202 | Accepted | 請求被接受,但未處理完 |
| 203 | Non-authoritative Information | |
| 204 | No Content | |
| 205 | Reset Content | |
| 206 | Partial Content | |
| 300 | Multiple Choices | 一個超鏈接表,用戶可以選擇一個超鏈接並訪問,最大支持5個超鏈接 |
| 301 | Moved Permanently | 被請求的頁面已經移動到了新的URL下 |
| 302 | Found | 被請求的頁面暫時性地移動到了新的URL下 |
| 303 | See Other | 被請求的頁面可以在一個不同的URL下找到 |
| 304 | Not Modified | |
| 305 | Use Proxy | |
| 306 | Unused | 已經不再使用此狀態碼,但狀態碼被保留 |
| 307 | Temporary Redirect | 被請求的頁面暫時性地移動到了新的URL下 |
| 400 | Bad Request | 服務器無法識別請求 |
| 401 | Unauthorized | 被請求的頁面需要用戶名和密碼 |
| 402 | Payment Required | 目前還不能使用此狀態碼 |
| 403 | Forbidden | 禁止訪問所請求的頁面 |
| 404 | Not Found | 服務器無法找到所請求的頁面 |
| 405 | Method Not Allowed | 請求中所指定的方法不被允許 |
| 406 | Not Acceptable | 服務器只能創建一個客戶端無法接受的響應 |
| 407 | Proxy Authentication Required | 在請求被服務前必須認證一個代理服務器 |
| 408 | Request Timeout | 請求時間超過了服務器所能等待的時間,連接被斷開 |
| 409 | Conflict | 請求有矛盾的地方 |
| 410 | Gone | 被請求的頁面不再可用 |
| 411 | Length Required | "Content-Length"沒有被定義,服務器拒絕接受請求 |
| 412 | Precondition Failed | 請求的前提條件被服務器評估為false |
| 413 | Request Entity Too Large | 因為請求的實體太大,服務器拒絕接受請求 |
| 414 | Request-url Too Long | 服務器拒絕接受請求,因為URL太長。多出現在把"POST"請求轉換為"GET"請求時所附帶的大量查詢信息 |
| 415 | Unsupported Media Type | 服務器拒絕接受請求,因為媒體類型不被支持 |
| 417 | Expectation Failed | |
| 500 | Internal Server Error | 請求不完整,服務器遇見了出乎意料的狀況 |
| 501 | Not Implemented | 請求不完整,服務器不提供所需要的功能 |
| 502 | Bad Gateway | 請求不完整,服務器從上游服務器接受了一個無效的響應 |
| 503 | Service Unavailable | 請求不完整,服務器暫時重啟或關閉 |
| 504 | Gateway Timeout | 網關超時 |
| 505 | HTTP Version Not Supported |
1.HTTP報文介紹
HTTP報文:用於HTTP協議交互的信息.
HTTP報文由報文頭部和報文主體(非必須)構成,中間由空行來分隔.
1.1 請求報文:客戶端發起的報文.
1).報文頭部:
(1)請求行:包含請求的方法,URI和HTTP版本號.
(2)請求頭部字段.
(3)通用頭部字段
(4)實體頭部字段
2).空行
3).報文主體
1.2.響應報文:服務單響應的報文.
1).報文頭部:
(1)狀態行:包含表示請求響應的狀態碼,原因短語,和HTTP版本.
(2)響應頭部字段.
(3)通用頭部字段
(4)實體頭部字段
2).空行
3).報文主體
頭部字段:包含表示請求或響應的各種條件和屬性的各種頭部信息
2.傳輸速率的提升
2.1 對傳輸數據進行壓縮編碼,常見的編碼:
(1)Gzip : GUN zip
(2)compress : Unix系統的標准壓縮
(3)deflate : zlib
(4)identity : 不編碼
2.2 分塊傳輸編碼.
允許HTTP由網頁服務器發送給客戶端應用(通常是網頁瀏覽器)的數據可以分成多個部分。分塊傳輸編碼只在HTTP協議1.1版本(HTTP/1.1)中提供。
3.多部分對象集合
HTTP協議中采納了多部分對象集合,發送的一份報文主體可能含有多類型實體.通常是在圖片或文本文件等上傳時使用.
multipart/form-data : 在Web表單文件上傳時使用.
|
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
|
POST/XXXXX HTTP/1.1
Accept: text/plain, */*
Accept-Language: zh-cn
Host: 192.168.24.56
Content-Type:multipart/form-data;boundary=-----------------------------7db372eb000e2
User-Agent: WinHttpClient
Content-Length: 3693
Connection: Keep-Alive
-------------------------------7db372eb000e2
Content-Disposition: form-data; name="file"; filename="kn.jpg"
Content-Type: image/jpeg
(此處省略jpeg文件二進制數據...)
-------------------------------7db372eb000e2--
|
multipart/byteranges:狀態碼206 響應報文包含了多個范圍的內容時使用.
二.狀態碼
HTTP狀態碼
當瀏覽者訪問一個網頁時,瀏覽者的瀏覽器會向網頁所在服務器發出請求。當瀏覽器接收並顯示網頁前,此網頁所在的服務器會返回一個包含HTTP狀態碼的信息頭(server header)用以響應瀏覽器的請求。
HTTP狀態碼的英文為HTTP Status Code
下面是常見的HTTP狀態碼:
- 200 – 請求成功
- 301 – 資源(網頁等)被永久轉移到其它URL
- 404 – 請求的資源(網頁等)不存在
- 500 – 內部服務器錯誤
HTTP狀態碼分類
HTTP狀態碼由三個十進制數字組成,第一個十進制數字定義了狀態碼的類型,后兩個數字沒有分類的作用。HTTP狀態碼共分為5種類型:
| 分類 | 分類描述 |
|---|---|
| 1** | 信息,服務器收到請求,需要請求者繼續執行操作 |
| 2** | 成功,操作被成功接收並處理 |
| 3** | 重定向,需要進一步的操作以完成請求 |
| 4** | 客戶端錯誤,請求包含語法錯誤或無法完成請求 |
| 5** | 服務器錯誤,服務器在處理請求的過程中發生了錯誤 |
HTTP狀態碼列表
| 狀態碼 | 狀態碼英文名稱 | 中文描述 |
|---|---|---|
| 100 | Continue | 繼續。客戶端應繼續其請求 |
| 101 | Switching Protocols | 切換協議。服務器根據客戶端的請求切換協議。只能切換到更高級的協議,例如,切換到HTTP的新版本協議 |
| 200 | OK | 請求成功。一般用於GET與POST請求 |
| 201 | Created | 已創建。成功請求並創建了新的資源 |
| 202 | Accepted | 已接受。已經接受請求,但未處理完成 |
| 203 | Non-Authoritative Information | 非授權信息。請求成功。但返回的meta信息不在原始的服務器,而是一個副本 |
| 204 | No Content | 無內容。服務器成功處理,但未返回內容。在未更新網頁的情況下,可確保瀏覽器繼續顯示當前文檔 |
| 205 | Reset Content | 重置內容。服務器處理成功,用戶終端(例如:瀏覽器)應重置文檔視圖。可通過此返回碼清除瀏覽器的表單域 |
| 206 | Partial Content | 部分內容。服務器成功處理了部分GET請求 |
| 300 | Multiple Choices | 多種選擇。請求的資源可包括多個位置,相應可返回一個資源特征與地址的列表用於用戶終端(例如:瀏覽器)選擇 |
| 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請求重定向 |
| 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的請求頭信息 |
| 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協議的版本,無法完成處理 |
