200 – 伺服器成功返回網頁 404 – 請求的網頁不存在 503 – 服務不可用
1xx(臨時響應)
表示臨時響應並需要請求者繼續執行操作的狀態**。
** 說明
100 (繼續) 請求者應當繼續提出請求。 伺服器返回此**表示已收到請求的第一部分,正在等待其餘部分。
101 (切換協議) 請求者已要求伺服器切換協議,伺服器已確認並準備切換。
2xx (成功)
表示成功處理了請求的狀態**。
** 說明
200 (成功) 伺服器已成功處理了請求。 通常,這表示伺服器提供了請求的網頁。
201 (已建立) 請求成功並且伺服器建立了新的資源。
202 (已接受) 伺服器已接受請求,但尚未處理。
203 (非授權資訊) 伺服器已成功處理了請求,但返回的資訊可能來自另一**。
204 (無內容) 伺服器成功處理了請求,但沒有返回任何內容。
205 (重置內容) 伺服器成功處理了請求,但沒有返回任何內容。
206 (部分內容) 伺服器成功處理了部分 get 請求。
3xx (重定向)
表示要完成請求,需要進一步操作。 通常,這些狀態**用來重定向。
** 說明
300 (多種選擇) 針對請求,伺服器可執行多種操作。 伺服器可根據請求者 (user agent) 選擇一項操作,或提供操作列表供請求者選擇。
301 (永久移動) 請求的網頁已永久移動到新位置。 伺服器返回此響應(對 get 或 head 請求的響應)時,會自動將請求者轉到新位置。
302 (臨時移動) 伺服器目前從不同位置的網頁響應請求,但請求者應繼續使用原有位置來進行以後的請求。
303 (檢視其他位置) 請求者應當對不同的位置使用單獨的 get 請求來檢索響應時,伺服器返回此**。
304 (未修改) 自從上次請求後,請求的網頁未修改過。 伺服器返回此響應時,不會返回網頁內容。
305 (使用**) 請求者只能使用**訪問請求的網頁。 如果伺服器返回此響應,還表示請求者應使用**。
307 (臨時重定向) 伺服器目前從不同位置的網頁響應請求,但請求者應繼續使用原有位置來進行以後的請求。
4xx(請求錯誤)
這些狀態**表示請求可能出錯,妨礙了伺服器的處理。
** 說明
400 (錯誤請求) 伺服器不理解請求的語法。
401 (未授權) 請求要求身份驗證。 對於需要登入的網頁,伺服器可能返回此響應。
403 (禁止) 伺服器拒絕請求。
404 (未找到) 伺服器找不到請求的網頁。
405 (方法禁用) 禁用請求中指定的方法。
406 (不接受) 無法使用請求的內容特性響應請求的網頁。
407 (需要**授權) 此狀態**與 401(未授權)類似,但指定請求者應當授權使用**。
408 (請求超時) 伺服器等候請求時發生超時。
409 (衝突) 伺服器在完成請求時發生衝突。 伺服器必須在響應中包含有關衝突的資訊。
410 (已刪除) 如果請求的資源已永久刪除,伺服器就會返回此響應。
411 (需要有效長度) 伺服器不接受不含有效內容長度標頭字段的請求。
412 (未滿足前提條件) 伺服器未滿足請求者在請求中設定的其中乙個前提條件。
413 (請求實體過大) 伺服器無法處理請求,因為請求實體過大,超出伺服器的處理能力。
414 (請求的 uri 過長) 請求的 uri(通常為**)過長,伺服器無法處理。
415 (不支援的**型別) 請求的格式不受請求頁面的支援。
416 (請求範圍不符合要求) 如果頁面無法提供請求的範圍,則伺服器會返回此狀態**。
417 (未滿足期望值) 伺服器未滿足」期望」請求標頭字段的要求。
5xx(伺服器錯誤)
這些狀態**表示伺服器在嘗試處理請求時發生內部錯誤。 這些錯誤可能是伺服器本身的錯誤,而不是請求出錯。
** 說明
500 (伺服器內部錯誤) 伺服器遇到錯誤,無法完成請求。
501 (尚未實施) 伺服器不具備完成請求的功能。 例如,伺服器無法識別請求方法時可能會返回此**。
502 (錯誤閘道器) 伺服器作為閘道器或**,從上游伺服器收到無效響應。
503 (服務不可用) 伺服器目前無法使用(由於超載或停機維護)。 通常,這只是暫時狀態。
504 (閘道器超時) 伺服器作為閘道器或**,但是沒有及時從上游伺服器收到請求。
505 (http 版本不受支援) 伺服器不支援請求中所用的 http 協議版本。
rfc 6585 最近剛剛發布,該文件描述了 4 個新的 http 狀態碼。
http 協議還在變化?是的,http 協議一直在演變,新的狀態碼對於開發 rest 服務或者說是基於 http 的服務非常有用,下面我們為你詳細介紹這四個新的狀態碼以及是否應該使用。
428 precondition required (要求先決條件)
先決條件是客戶端傳送 http 請求時,如果想要請求能成功必須滿足一些預設的條件。
乙個好的例子就是 if-none-match 頭,經常在 get 請求中使用,如果指定了 if-none-match ,那麼客戶端只在響應中的 etag 改變後才會重新接收回應。
先決條件的另外乙個例子就是 if-match 頭,這個一般用在 put 請求上用於指示只更新沒被改變的資源,這在多個客戶端使用 http 服務時用來防止彼此間不會覆蓋相同內容。
當伺服器端使用 428 precondition required 狀態碼時,表示客戶端必須傳送上述的請求頭才能執行請求,這個方法為伺服器提供一種有效的方法來阻止 'lost update' 問題。
429 too many requests (太多請求)
當你需要限制客戶端請求某個服務數量時,該狀態碼就很有用,也就是請求速度限制。
在此之前,有一些類似的狀態碼,例如 '509 bandwidth limit exceeded'. twitter 使用 420 (這不是http定義的狀態碼)
如果你希望限制客戶端對服務的請求數,可使用 429 狀態碼,同時包含乙個 retry-after 響應頭用於告訴客戶端多長時間後可以再次請求服務。
431 request header fields too large (請求頭欄位太大)
某些情況下,客戶端傳送 http 請求頭會變得很大,那麼伺服器可傳送 431 request header fields too large 來指明該問題。
我不太清楚為什麼沒有 430 狀態碼,而是直接從 429 跳到 431,我嘗試搜尋但沒有結果。唯一的猜測是 430 forbidden 跟 403 forbidden 太像了,為了避免混淆才這麼做的,天知道!
511 network authentication required (要求網路認證)
對我來說這個狀態碼很有趣,如果你在開發乙個 http 伺服器,你不一定需要處理該狀態碼,但如果你在編寫 http 客戶端,那這個狀態碼就非常重要。
如果你頻繁使用筆記本和智慧型手機,你可能會注意到大量的公用 wifi 服務要求你必須接受一些協議或者必須登入後才能使用。
這是通過攔截http流量,當使用者試圖訪問網路返回乙個重定向和登入,這很討厭,但是實際情況就是這樣的。
使用這些「攔截」客戶端,會有一些討厭的***。在 rfc 中有提到這兩個的例子:
因此 511 狀態碼的提出就是為了解決這個問題。
如果你正在編寫 http 的客戶端,你最好還是檢查 511 狀態碼以確認是否需要認證後才能訪問。
HTTP世界一覽
正式名稱是 internet,上網 實際上是訪問網際網路的子集全球資訊網,它基於 http 協議,傳輸 html 等超文字資源 還有許多全球資訊網之外的資源,例如 電子郵件,bt,ftp,ssh等,需要各自專有協議訪問 web browser,檢索檢視網際網路網頁資源的應用程式。在 http 協議中...
Http傳輸Header一覽
response header date 伺服器端時間 server 伺服器端的伺服器軟體 apache 2.2.6 etag 檔案識別符號 content encoding傳送啟用了gzip壓縮 gzip content length 內容長度 content type 內容型別 請求header...
http狀態碼一覽表
1 請求收到,繼續處理 2 操作成功收到,分析 接受 3 完成此請求必須進一步處理 4 請求包含乙個錯誤語法或不能完成 5 伺服器執行乙個完全有效請求失敗 100 客戶必須繼續發出請求 101 客戶要求伺服器根據請求轉換http協議版本 200 交易成功 201 提示知道新檔案的url 202 接受...