Http報文 狀態碼


簡表

狀態碼 消息 描述
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
一.HTTP報文

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種類型:

HTTP狀態碼分類
分類 分類描述
1** 信息,服務器收到請求,需要請求者繼續執行操作
2** 成功,操作被成功接收並處理
3** 重定向,需要進一步的操作以完成請求
4** 客戶端錯誤,請求包含語法錯誤或無法完成請求
5** 服務器錯誤,服務器在處理請求的過程中發生了錯誤

HTTP狀態碼列表

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協議的版本,無法完成處理

原創文章,轉載請注明: 轉載自熊貓大仙技術博客

本文鏈接地址: 熊貓說HTTP(2)–報文與狀態碼


pasting


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM