2XX 響應的結果標明請求被正常處理了瀏覽器
表示從客戶端發來的請求在服務器端被正常處理了服務器
在響應報文內,隨狀態碼一塊兒返回的信息會因方法的不一樣而發生改變。好比,使用 GET 方法時,對應請求資源的實體會做爲響應返回;而使用 HEAD 方法 時,對應請求資源的實體首部不隨報文主體做爲響應返回(即在響應中只返回首部,不會返回實體的主體部分)。spa
該狀態碼錶明服務器接收的請求已成功處理,但在返回的響應報文中不含實體的主體部分。另外,也不容許返回任何實體的主體。好比,當從瀏覽器發出請求 處理後,返回 204 響應,那麼瀏覽器顯示的頁面不發生更新。代理
通常在只須要從客戶端往服務器發送信息,而對客戶端不須要發送新信息內容的狀況下使用code
該狀態碼錶示客戶端進行了範圍請求,而服務器成功執行了這部分的 GET 請求
響應報文中包含由 Content-Range 指定範圍的實體內容cdn
3XX 響應結果代表瀏覽器須要執行某些特殊的處理以正確處理請求blog
永久性重定向圖片
該狀態碼錶示請求的資源已被分配了新的 URI,之後應使用資源如今所指的 URI。也就是說,若是已經把資源對應的 URI 保存爲書籤了,這時應該按 Location 首部字段提示的 URI 從新保存資源
臨時性重定向get
該狀態碼錶示請求的資源已被分配了新的 URI,但願用戶(本次)能使用新的 URI 訪問。 和 301 Moved Permanently 狀態碼類似,但 302 狀態碼錶明的資源不是被永久移動,只是臨時性質的。換句話說,已移動的資源對應的 URI 未來還有可能發生改 變。好比,用戶把 URI 保存成書籤,但不會像 301 狀態碼出現時那樣去更新書籤,而是仍舊保留返回 302 狀態碼的頁面對應的 URI。
該狀態碼錶示因爲請求對應的資源存在着另外一個 URI,應使用 GET 方法定向獲取請求的資源。
303 狀態碼和 302 Found 狀態碼有着相同的功能,但 303 狀態碼明確表示客戶端應當採用 GET 方法獲取資源,這點與 302 狀態碼有區別。 好比,當使用 POST 方法訪問 CGI 程序,其執行後的處理結果是但願客戶端能以 GET 方法重定向到另外一個 URI 上去時,返回 303 狀態碼。雖然 302 Found 狀態碼也能夠實現相同的功能,但這裏使用 303 狀態碼是最理想的
當 30一、30二、303 響應狀態碼返回時,幾乎全部的瀏覽器都會把 POST 改爲 GET,並刪除請求報文內的主體,以後請求會自動再次發送
30一、302 標準是禁止將 POST 方法改變成 GET 方法的,但實際使用時你們都會這麼作
該狀態碼錶示客戶端發送附帶條件的請求時,服務器端容許請求訪問資源,但未知足條件的狀況。304 狀態碼返回時,不包含任何響應的主體部分。304 雖 然被劃分在 3XX 類別中,可是和重定向沒有關係。
附帶條件的請求是指採用 GET 方法的請求報文中包含 If-Match,If-Modified-Since,If-None-Match,If-Range,If-Unmodified-Since 中任一首部
臨時重定向。該狀態碼與 302 Found 有着相同的含義。儘管 302 標準禁止 POST 變換成 GET,但實際使用時你們並不遵照
307 會遵守瀏覽器標準,不會從 POST 變成 GET。可是,對於處理響應時的行爲,每種瀏覽器有可能出現不一樣的狀況
4XX 的響應結果代表客戶端是發生錯誤的緣由所在
該狀態碼錶示請求報文中存在語法錯誤。當錯誤發生時,需修改請求的內容後再次發送請求。另外,瀏覽器會像 200 OK 同樣對待該狀態碼。
該狀態碼錶示發送的請求須要有經過 HTTP 認證(BASIC 認證、DIGEST 認證)的認證信息。另外若以前已進行過 1 次請求,則表示用 戶認證失敗
返回含有 401 的響應必須包含一個適用於被請求資源的 WWW-Authenticate 首部用以質詢(challenge)用戶信息。當瀏覽器初次接收到 401 響應,會彈出認證用的對話窗口
該狀態碼代表對請求資源的訪問被服務器拒絕了。服務器端沒有必要給出拒絕的詳細理由,但若是想做說明的話,能夠在實體的主體部分對緣由進行描述,這樣就能讓用戶看到了
未得到文件系統的訪問受權,訪問權限出現某些問題(從未受權的發送源 IP 地址試圖訪問)等列舉的狀況均可能是發生 403 的緣由
該狀態碼代表服務器上沒法找到請求的資源。除此以外,也能夠在服務器端拒絕請求且不想說明理由時使用
該狀態碼標明,客戶端請求的方法雖然能被服務器識別,可是服務器禁止使用該方法
GET 和 HEAD 方法,服務器應該老是容許客戶端進行訪問
客戶端能夠經過 OPTIONS 方法來查看服務器容許的訪問方法, 以下
Access-Control-Allow-Methods →GET,HEAD,PUT,PATCH,POST,DELETE
複製代碼
5XX 的響應結果代表服務器自己發生錯誤
該狀態碼代表服務器端在執行請求時發生了錯誤。也有多是 Web 應用存在的 bug 或某些臨時的故障
該狀態碼代表扮演網關或代理角色的服務器,從上游服務器中接收到的響應是無效的
502 錯誤一般不是客戶端可以修復的,而是須要由途徑的 Web 服務器或者代理服務器對其進行修復
該狀態碼代表服務器暫時處於超負載或正在進行停機維護,如今沒法處理請求。若是事先得知解除以上情況須要的時間,最好寫入 RetryAfter 首部字段再返回 給客戶端
狀態碼和情況的不一致
很多返回的狀態碼響應都是錯誤的,可是用戶可能察覺不到這點。好比 Web 應用程序內部發生錯誤,狀態碼依然返回 200 OK,這種狀況也常常遇到。
本文中使用到的圖片均來自於圖解HTTP,若有侵權,望周知