1. 程式人生 > >python介面http網路請求 返回常見statusCode(狀態碼)解釋

python介面http網路請求 返回常見statusCode(狀態碼)解釋

當瀏覽者訪問一個網頁時,瀏覽者的瀏覽器會向網頁所在伺服器發出請求。當瀏覽器接收並顯示網頁前,此網頁所在的伺服器會返回一個包含HTTP狀態碼的資訊頭(server header)用以響應瀏覽器的請求。

HTTP狀態碼由三個十進位制數字組成,第一個十進位制數字定義了狀態碼的型別,後兩個數字沒有分類的作用。HTTP狀態碼共分為5種類型:

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

詳細資訊

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網路請求 返回statusCode(狀態碼) 200、300、400、500。。。。

201-206都表示伺服器成功處理了請求的狀態程式碼,說明網頁可以正常訪問。         200(成功)  伺服器已成功處理了請求。通常,這表示伺服器提供了請求的網頁。         201(已建立)  請求成功且伺服器已建立了新的資源。          202(已接受)  伺服器已接受了請求,但尚未對其進行處理。          203(非授權資訊)  伺服器已成功處理了請求,但返回了可能來自另一來源的資訊。          204(無內容)  伺服器成功處理了請求,但未返回任何內容。          205(重置內容) 伺服器成功處理了請求,但未返回任何內容。與 204 響應不同,此響應要求請求者重置文件檢視(例如清除表單內容以輸入新內容)。          206(部分內容)  伺服器成功處理了部分 GET 請求。         300-3007表示的意思是:要完成請求,您需要進一步進行操作。通常,這些狀態程式碼是永遠重定向的。         300(多種選擇)  伺服器根據請求可執行多種操作。伺服器可根據請求者 來選擇一項操作,或提供操作列表供其選擇。          301(永久移動)  請求的網頁已被永久移動到新位置。伺服器返回此響應時,會自動將請求者轉到新位置。您應使用此程式碼通知搜尋引擎蜘蛛網頁或網站已被永久移動到新位置。          302(臨時移動) 伺服器目前正從不同位置的網頁響應請求,但請求者應繼續使用原有位置來進行以後的請求。會自動將請求者轉到不同的位置。但由於搜尋引擎會繼續抓取原有位置並將其編入索引,因此您不應使用此程式碼來告訴搜尋引擎頁面或網站已被移動。          303(檢視其他位置) 當請求者應對不同的位置進行單獨的 GET 請求以檢索響應時,伺服器會返回此程式碼。對於除 HEAD 請求之外的所有請求,伺服器會自動轉到其他位置。          304(未修改) 自從上次請求後,請求的網頁未被修改過。伺服器返回此響應時,不會返回網頁內容。         如果網頁自請求者上次請求後再也沒有更改過,您應當將伺服器配置為返回此響應。由於伺服器可以告訴 搜尋引擎自從上次抓取後網頁沒有更改過,因此可節省頻寬和開銷。          305(使用代理) 請求者只能使用代理訪問請求的網頁。如果伺服器返回此響應,那麼,伺服器還會指明請求者應當使用的代理。          307(臨時重定向)  伺服器目前正從不同位置的網頁響應請求,但請求者應繼續使用原有位置來進行以後的請求。會自動將請求者轉到不同的位置。但由於搜尋引擎會繼續抓取原有位置並將其編入索引,因此您不應使用此程式碼來告訴搜尋引擎某個頁面或網站已被移動。         4XXHTTP狀態碼錶示請求可能出錯,會妨礙伺服器的處理。         400(錯誤請求) 伺服器不理解請求的語法。          401(身份驗證錯誤) 此頁要求授權。您可能不希望將此網頁納入索引。          403(禁止) 伺服器拒絕請求。         404(未找到) 伺服器找不到請求的網頁。例如,對於伺服器上不存在的網頁經常會返回此程式碼。         例如:

http://www.0631abc.com/20100aaaa,就會進入404錯誤頁面         405(方法禁用) 禁用請求中指定的方法。         406(不接受) 無法使用請求的內容特性響應請求的網頁。          407(需要代理授權) 此狀態碼與 401 類似,但指定請求者必須授權使用代理。如果伺服器返回此響應,還表示請求者應當使用代理。          408(請求超時) 伺服器等候請求時發生超時。          409(衝突) 伺服器在完成請求時發生衝突。伺服器必須在響應中包含有關衝突的資訊。伺服器在響應與前一個請求相沖突的 PUT 請求時可能會返回此程式碼,以及兩個請求的差異列表。          410(已刪除) 請求的資源永久刪除後,伺服器返回此響應。該程式碼與 404(未找到)程式碼相似,但在資源以前存在而現在不存在的情況下,有時會用來替代 404 程式碼。如果資源已永久刪除,您應當使用 301 指定資源的新位置。          411(需要有效長度) 伺服器不接受不含有效內容長度標頭欄位的請求。          412(未滿足前提條件) 伺服器未滿足請求者在請求中設定的其中一個前提條件。          413(請求實體過大) 伺服器無法處理請求,因為請求實體過大,超出伺服器的處理能力。          414(請求的 URI 過長) 請求的 URI(通常為網址)過長,伺服器無法處理。          415(不支援的媒體型別) 請求的格式不受請求頁面的支援。          416(請求範圍不符合要求) 如果頁面無法提供請求的範圍,則伺服器會返回此狀態碼。          417(未滿足期望值) 伺服器未滿足"期望"請求標頭欄位的要求。                 500至505表示的意思是:伺服器在嘗試處理請求時發生內部錯誤。這些錯誤可能是伺服器本身的錯誤,而不是請求出錯。                 500(伺服器內部錯誤)  伺服器遇到錯誤,無法完成請求。                  501(尚未實施) 伺服器不具備完成請求的功能。例如,當伺服器無法識別請求方法時,伺服器可能會返回此程式碼。                  502(錯誤閘道器) 伺服器作為閘道器或代理,從上游伺服器收到了無效的響應。                  503(服務不可用) 目前無法使用伺服器(由於超載或進行停機維護)。通常,這只是一種暫時的狀態。                  504(閘道器超時)  伺服器作為閘道器或代理,未及時從上游伺服器接收請求。                  505(HTTP 版本不受支援) 伺服器不支援請求中所使用的 HTTP 協議版本。