HTTP 返回值標準含義

愛新覺羅罹江發表於2019-01-16

2xx     成功

 

200     正常;請求已完成。

 

201     正常;緊接 POST 命令。

 

202     正常;已接受用於處理,但處理尚未完成。

 

203     正常;部分資訊 — 返回的資訊只是一部分。

 

204     正常;無響應 — 已接收請求,但不存在要回送的資訊。

 

3xx     重定向

 

301     已移動 — 請求的資料具有新的位置且更改是永久的。

 

302     已找到 — 請求的資料臨時具有不同 URI。

 

303     請參閱其它 — 可在另一 URI 下找到對請求的響應,且應使用 GET 方法檢索此響應。

 

304     未修改 — 未按預期修改文件。

 

305     使用代理 — 必須通過位置欄位中提供的代理來訪問請求的資源。

 

306     未使用 — 不再使用;保留此程式碼以便將來使用。

 

4xx     客戶機中出現的錯誤

 

400     錯誤請求 — 請求中有語法問題,或不能滿足請求。

 

401     未授權 — 未授權客戶機訪問資料。

 

402     需要付款 — 表示計費系統已有效。

 

403     禁止 — 即使有授權也不需要訪問。

 

404     找不到 — 伺服器找不到給定的資源;文件不存在。

 

407     代理認證請求 — 客戶機首先必須使用代理認證自身。

 

410     請求的網頁不存在(永久);

 

415     介質型別不受支援 — 伺服器拒絕服務請求,因為不支援請求實體的格式。

 

5xx     伺服器中出現的錯誤

 

500     內部錯誤 — 因為意外情況,伺服器不能完成請求。

 

501     未執行 — 伺服器不支援請求的工具。

 

502     錯誤閘道器 — 伺服器接收到來自上游伺服器的無效響應。

 

503     無法獲得服務 — 由於臨時過載或維護,伺服器無法處理請求。

 

100系列碼

 

從100到199範圍的HTTP狀態碼是資訊報告碼。基於各種原因考慮,大多數情況下我們是很少看見這些程式碼的。首先,如果一個瀏覽器嘗試訪問一個網站,而網站返回這些程式碼時,它們往往都不會顯示在螢幕上。它們只是瀏覽器使引用的內部碼。另外,這些程式碼不常見的另外一個原因是起初HTTP標準不允許使用這一範圍的狀態碼。就其本身而言,它們也一直沒有被廣泛地使用。

 

200系列碼

 

從 200到299範圍的狀態碼是操作成功程式碼。同樣的,在正常的Web上網中,你也很可能不曾在螢幕上看到這些程式碼。相反的,這些程式碼是在瀏覽器內部使用的,用以確認操作成功確認和當前請求狀態。雖然這些程式碼通常不顯示,但是有一些故障排除工具能夠讀到它們,就像和其它大多數的HTTP狀態碼一樣,它們在錯誤診斷過程中是非常有用的。

 

300系列碼

 

從300到399範圍的狀態碼是重定向程式碼。本質上,它們告訴Web瀏覽器必須執行其它一些操作以完成請求。基於這個命令的特點,它可以自動地執行,或者要求額外的使用者輸入。比如,狀態碼 301表示一個特定資源已經被永久地先移除,因此將來所有訪問該資源請求都應該定向到一個特定的URL上。

 

400系列碼

 

在 400範圍的狀態碼是客戶端錯誤碼。這種型別的錯誤碼往往跟安全相關。比如,如果一個客戶端嘗試訪問一個未授權訪問的資源,伺服器就會返回一個狀態碼 401。類似地,如果客戶端嘗試訪問一個禁止的資源,在這種情況下客戶端的認證狀態是一樣的,那麼伺服器可能會返回一個狀態碼403,表示禁止對該資源進行訪問。

 

如果請求不正確或客戶端超時,400級錯誤碼也可能被返回。然而,有一個400級的程式碼總是具有誤導性:404。雖然這個程式碼在技術上被歸類為客戶端錯誤,但是事實上它可以同時表示客戶端或伺服器上的錯誤。但這個錯誤碼只是簡單地顯示為沒有找到請求的資源。當這個錯誤發生在客戶端時,它往往表示的是網路連線問題。在其他時候,這個錯誤的發生還可能是由於資源已從伺服器上轉移或重新命名而造成的。

 

500系列碼

 

500 級狀態碼錶示的是伺服器錯誤。比如,如果Web伺服器超時,它就會產生一個504錯誤。雖然,一個500級的錯誤往往表示的不是伺服器的問題,而是在伺服器上執行的Web應用的問題。比如,我自己的個人網站是用ASP編寫的,它負責動態生成HTML網頁。在除錯的過程中,有Bug的程式碼總會導致我的Web 伺服器返回HTTP狀態碼500,該程式碼是一般表示內部伺服器錯誤。這個程式碼只是出現問題了,並且HTTP無法解決該問題。

 

-----------------------------------------

 

1xx - 資訊提示

 

"100":Continue

 

"101":witchingProtocols

 

2xx - 成功

 

"200":OK

 

"201":Created

 

"202":Accepted

 

"203":Non-AuthoritativeInformation

 

"204":NoContent

 

"205":ResetContent

 

"206":PartialContent

 

3xx - 重定向

 

"300":MultipleChoices

 

"301":MovedPermanently

 

"302":Found

 

"303":SeeOther

 

"304":NotModified

 

"305":UseProxy

 

"307":TemporaryRedirect

 

4xx - 客戶端錯誤

 

"400":BadRequest

 

"401":Unauthorized

 

"402":PaymentRequired

 

"403":Forbidden

 

"404":NotFound

 

"405":MethodNotAllowed

 

"406":NotAcceptable

 

"407":ProxyAuthenticationRequired

 

"408":RequestTime-out

 

"409":Conflict

 

"410":Gone

 

"411":LengthRequired

 

"412":PreconditionFailed

 

"413":RequestEntityTooLarge

 

"414":Request-URITooLarge

 

"415":UnsupportedMediaType

 

"416":Requestedrangenotsatisfiable

 

"417":ExpectationFailed

 

5xx - 伺服器錯誤

 

"500":InternalServerError

 

"501":NotImplemented

 

"502":BadGateway

 

"503":ServiceUnavailable

 

"504":GatewayTime-out

 

"505":HTTPVersionnotsupported

 

狀態程式碼

 

狀態資訊

 

含義

 

100

 

Continue

 

初始的請求已經接受,客戶應當繼續傳送請求的其餘部分。(HTTP 1.1新)

 

101

 

Switching Protocols

 

伺服器將遵從客戶的請求轉換到另外一種協議(HTTP 1.1新)

 

200

 

OK

 

一切正常,對GET和POST請求的應答文件跟在後面。

 

201

 

Created

 

伺服器已經建立了文件,Location頭給出了它的URL。

 

202

 

Accepted

 

已經接受請求,但處理尚未完成。

 

203

 

Non-Authoritative Information

 

文件已經正常地返回,但一些應答頭可能不正確,因為使用的是文件的拷貝(HTTP 1.1新)。

 

204

 

No Content

 

沒有新文件,瀏覽器應該繼續顯示原來的文件。如果使用者定期地重新整理頁面,而Servlet可以確定使用者文件足夠新,這個狀態程式碼是很有用的。

 

205

 

Reset Content

 

沒有新的內容,但瀏覽器應該重置它所顯示的內容。用來強制瀏覽器清除表單輸入內容(HTTP 1.1新)。

 

206

 

Partial Content

 

客戶傳送了一個帶有Range頭的GET請求,伺服器完成了它(HTTP 1.1新)。

 

300

 

Multiple Choices

 

客戶請求的文件可以在多個位置找到,這些位置已經在返回的文件內列出。如果伺服器要提出優先選擇,則應該在Location應答頭指明。

 

301

 

Moved Permanently

 

客戶請求的文件在其他地方,新的URL在Location頭中給出,瀏覽器應該自動地訪問新的URL。

 

302

 

Found

 

類似於301,但新的URL應該被視為臨時性的替代,而不是永久性的。注意,在HTTP1.0中對應的狀態資訊是“Moved Temporatily”。

 

出現該狀態程式碼時,瀏覽器能夠自動訪問新的URL,因此它是一個很有用的狀態程式碼。

 

注意這個狀態程式碼有時候可以和301替換使用。例如,如果瀏覽器錯誤地請求http://host/~user(缺少了後面的斜槓),有的伺服器返回301,有的則返回302。

 

嚴格地說,我們只能假定只有當原來的請求是GET時瀏覽器才會自動重定向。請參見307。

 

303

 

See Other

 

類似於301/302,不同之處在於,如果原來的請求是POST,Location頭指定的重定向目標文件應該通過GET提取(HTTP 1.1新)。

 

304

 

Not Modified

 

客戶端有緩衝的文件併發出了一個條件性的請求(一般是提供If-Modified-Since頭表示客戶只想比指定日期更新的文件)。伺服器告訴客戶,原來緩衝的文件還可以繼續使用。

 

305

 

Use Proxy

 

客戶請求的文件應該通過Location頭所指明的代理伺服器提取(HTTP 1.1新)。

 

307

 

Temporary Redirect

 

和302 (Found)相同。許多瀏覽器會錯誤地響應302應答進行重定向,即使原來的請求是POST,即使它實際上只能在POST請求的應答是303時才能重定向。由於這個原因,HTTP 1.1新增了307,以便更加清除地區分幾個狀態程式碼:當出現303應答時,瀏覽器可以跟隨重定向的GET和POST請求;如果是307應答,則瀏覽器只能跟隨對GET請求的重定向。(HTTP 1.1新)

 

400

 

Bad Request

 

請求出現語法錯誤。

 

401

 

Unauthorized

 

客戶試圖未經授權訪問受密碼保護的頁面。應答中會包含一個WWW-Authenticate頭,瀏覽器據此顯示使用者名稱字/密碼對話方塊,然後在填寫合適的Authorization頭後再次發出請求。

 

403

 

Forbidden

 

資源不可用。伺服器理解客戶的請求,但拒絕處理它。通常由於伺服器上檔案或目錄的許可權設定導致。

 

404

 

Not Found

 

無法找到指定位置的資源。這也是一個常用的應答。

 

405

 

Method Not Allowed

 

請求方法(GET、POST、HEAD、DELETE、PUT、TRACE等)對指定的資源不適用。(HTTP 1.1新)

 

406

 

Not Acceptable

 

指定的資源已經找到,但它的MIME型別和客戶在Accpet頭中所指定的不相容(HTTP 1.1新)。

 

407

 

Proxy Authentication Required

 

類似於401,表示客戶必須先經過代理伺服器的授權。(HTTP 1.1新)

 

408

 

Request Timeout

 

在伺服器許可的等待時間內,客戶一直沒有發出任何請求。客戶可以在以後重複同一請求。(HTTP 1.1新)

 

409

 

Conflict

 

通常和PUT請求有關。由於請求和資源的當前狀態相沖突,因此請求不能成功。(HTTP 1.1新)

 

410

 

Gone

 

所請求的文件已經不再可用,而且伺服器不知道應該重定向到哪一個地址。它和404的不同在於,返回407表示文件永久地離開了指定的位置,而404表示由於未知的原因文件不可用。(HTTP 1.1新)

 

411

 

Length Required

 

伺服器不能處理請求,除非客戶傳送一個Content-Length頭。(HTTP 1.1新)

 

412

 

Precondition Failed

 

請求頭中指定的一些前提條件失敗(HTTP 1.1新)。

 

413

 

Request Entity Too Large

 

目標文件的大小超過伺服器當前願意處理的大小。如果伺服器認為自己能夠稍後再處理該請求,則應該提供一個Retry-After頭(HTTP 1.1新)。

 

414

 

Request URI Too Long

 

URI太長(HTTP 1.1新)。

 

416

 

Requested Range Not Satisfiable

 

伺服器不能滿足客戶在請求中指定的Range頭。(HTTP 1.1新)

 

500

 

Internal Server Error

 

伺服器遇到了意料不到的情況,不能完成客戶的請求。

 

501

 

Not Implemented

 

伺服器不支援實現請求所需要的功能。例如,客戶發出了一個伺服器不支援的PUT請求。

 

502

 

Bad Gateway

 

伺服器作為閘道器或者代理時,為了完成請求訪問下一個伺服器,但該伺服器返回了非法的應答。

 

503

 

Service Unavailable

 

伺服器由於維護或者負載過重未能應答。例如,Servlet可能在資料庫連線池已滿的情況下返回503。伺服器返回503時可以提供一個Retry-After頭。

 

504

 

Gateway Timeout

 

由作為代理或閘道器的伺服器使用,表示不能及時地從遠端伺服器獲得應答。(HTTP 1.1新)

 

505

 

HTTP Version Not Supported

 

伺服器不支援請求中所指明的HTTP版本。(HTTP 1.1新)

相關文章