伺服器返回的各種HTTP狀態碼
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新) |