常見的HTTP狀態代碼(HTTP Status Code)

來源:互聯網
上載者:User

標籤:service   錯誤碼   3.5   modified   after   判斷   author   rom   資料   

作為程式開發人員對於一些伺服器返回的HTTP狀態的意思都應該了如指掌,只有將這些狀態代碼一一弄清楚,工作中遇到的各種問題才能夠處理的得心應手。所以下面就讓我們來瞭解一下比較常見的HTTP狀態代碼吧!2**開頭 (請求成功)表示成功處理了請求的狀態碼。

200 (成功) 伺服器已成功處理了請求。 通常,這表示伺服器提供了請求的網頁。
201 (已建立) 請求成功並且伺服器建立了新的資源。
202 (已接受) 伺服器已接受請求,但尚未處理。
203 (非授權資訊) 伺服器已成功處理了請求,但返回的資訊可能來自另一來源。
204 (無內容) 伺服器成功處理了請求,但沒有返回任何內容。
205 (重設內容) 伺服器成功處理了請求,但沒有返回任何內容。
206 (部分內容) 伺服器成功處理了部分 GET 請求。

3** 開頭 (請求被重新導向)表示要完成請求,需要進一步操作。 通常,這些狀態碼用來重新導向。

300 (多種選擇) 針對請求,伺服器可執行多種操作。 伺服器可根據要求者 (user agent) 選擇一項操作,或提供巨集指令清單供要求者選擇。
301 (永久移動) 請求的網頁已永久移動到新位置。 伺服器返回此響應(對 GET 或 HEAD 請求的響應)時,會自動將要求者轉到新位置。
302 (臨時移動) 伺服器目前從不同位置的網頁響應請求,但要求者應繼續使用原有位置來進行以後的請求。
303 (查看其他位置) 要求者應當對不同的位置使用單獨的 GET 請求來檢索響應時,伺服器返回此代碼。
304 (未修改) 自從上次請求後,請求的網頁未修改過。 伺服器返回此響應時,不會返回網頁內容。
305 (使用代理) 要求者只能使用代理訪問請求的網頁。 如果伺服器返回此響應,還表示要求者應使用代理。
307 (臨時重新導向) 伺服器目前從不同位置的網頁響應請求,但要求者應繼續使用原有位置來進行以後的請求。

4**開頭 (請求錯誤)這些狀態碼表示請求可能出錯,妨礙了伺服器的處理。

400 (錯誤請求) 伺服器不理解請求的文法。
401 (未授權) 請求要求身分識別驗證。 對於需要登入的網頁,伺服器可能返回此響應。
403 (禁止) 伺服器拒絕請求。
404 (未找到) 伺服器找不到請求的網頁。
405 (方法禁用) 禁用請求中指定的方法。
406 (不接受) 無法使用請求的內容特性響應請求的網頁。
407 (需要代理授權) 此狀態碼與 401(未授權)類似,但指定要求者應當授權使用代理。
408 (請求逾時) 伺服器等候請求時發生逾時。
409 (衝突) 伺服器在完成請求時發生衝突。 伺服器必須在響應中包含有關衝突的資訊。
410 (已刪除) 如果請求的資源已永久刪除,伺服器就會返回此響應。
411 (需要有效長度) 伺服器不接受不含有效內容長度標題欄位的請求。
412 (未滿足前提條件) 伺服器未滿足要求者在請求中設定的其中一個前提條件。
413 (請求實體過大) 伺服器無法處理請求,因為請求實體過大,超出伺服器的處理能力。
414 (請求的 URI 過長) 請求的 URI(通常為網址)過長,伺服器無法處理。
415 (不支援的媒體類型) 請求的格式不受請求頁面的支援。
416 (請求範圍不符合要求) 如果頁面無法提供請求的範圍,則伺服器會返回此狀態碼。
417 (未滿足期望值) 伺服器未滿足"期望"請求標題欄位的要求。

5**開頭(伺服器錯誤)這些狀態碼表示伺服器在嘗試處理請求時發生內部錯誤。 這些錯誤可能是伺服器本身的錯誤,而不是請求出錯。

500 (伺服器內部錯誤) 伺服器遇到錯誤,無法完成請求。
501 (尚未實施) 伺服器不具備完成請求的功能。 例如,伺服器無法識別要求方法時可能會返回此代碼。
502 (錯誤網關) 伺服器作為網關或代理,從上遊伺服器收到無效響應。
503 (服務不可用) 伺服器目前無法使用(由於超載或停機維護)。 通常,這隻是暫時狀態。
504 (網關逾時) 伺服器作為網關或代理,但是沒有及時從上遊伺服器收到請求。
505 (HTTP 版本不受支援) 伺服器不支援要求中所用的 HTTP 協議版本。

1xx - 資訊提示

這些狀態碼表示臨時的響應。用戶端在收到常規響應之前,應準備接收一個或多個 1xx 響應。

· 100 - Continue 初始的請求已經接受,客戶應當繼續發送請求的其餘部分。(HTTP 1.1新)
· 101 - Switching Protocols 伺服器將遵從客戶的請求轉換到另外一種協議(HTTP 1.1新)

2xx - 成功
這類狀態碼表明伺服器成功地接受了用戶端請求。

· 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新)。

3xx - 重新導向
用戶端瀏覽器必須採取更多操作來實現請求。例如,瀏覽器可能不得不請求伺服器上的不同的頁面,或通過Proxy 伺服器重複該請求。

· 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頭所指明的Proxy 伺服器提取(HTTP 1.1新)。
· 307 - Temporary Redirect 和302(Found)相同。許多瀏覽器會錯誤地響應302應答進行重新導向,即使原來的請求是POST,即使它實際上只能在POST請求的應答是303時 才能重

定向。由於這個原因,HTTP 1.1新增了307,以便更加清除地區分幾個狀態碼:當出現303應答時,瀏覽器可以跟隨重新導向的GET和POST請求;如果是307應答,則瀏覽器只 能跟隨

對GET請求的重新導向。(HTTP 1.1新)

4xx - 用戶端錯誤
發生錯誤,用戶端似乎有問題。例如,用戶端請求不存在的頁面,用戶端未提供有效身分識別驗證資訊。

· 400 - Bad Request 請求出現語法錯誤。
· 401 - Unauthorized 訪問被拒絕,客戶試圖未經授權訪問受密碼保護的頁面。應答中會包含一個WWW-Authenticate頭,瀏覽器據此顯示使用者名稱字/密碼對話方塊,然後在 填寫合

適的Authorization頭後再次發出請求。IIS 定義了許多不同的 401 錯誤,它們指明更為具體的錯誤原因。這些具體的錯誤碼在瀏覽器中顯示,但不在 IIS 日誌中顯示:
· 401.1 - 登入失敗。
· 401.2 - 伺服器配置導致登入失敗。
· 401.3 - 由於 ACL 對資源的限制而未獲得授權。
· 401.4 - 篩選器授權失敗。
· 401.5 - ISAPI/CGI 應用程式授權失敗。
· 401.7 – 訪問被 Web 服務器上的 URL 授權策略拒絕。這個錯誤碼為 IIS 6.0 所專用。
· 403 - Forbidden 資源不可用。伺服器理解客戶的請求,但拒絕處理它。通常由於伺服器上檔案或目錄的使用權限設定導致。禁止訪問:IIS 定義了許多不同的 403 錯誤,它們指

明更為具體的錯誤原因:
· 403.1 - 執行訪問被禁止。
· 403.2 - 讀訪問被禁止。
· 403.3 - 寫訪問被禁止。
· 403.4 - 要求 SSL。
· 403.5 - 要求 SSL 128。
· 403.6 - IP 位址被拒絕。
· 403.7 - 要求用戶端認證。
· 403.8 - 網站訪問被拒絕。
· 403.9 - 使用者數過多。
· 403.10 - 配置無效。
· 403.11 - 密碼更改。
· 403.12 - 拒絕訪問映射表。
· 403.13 - 用戶端認證被吊銷。
· 403.14 - 拒絕目錄列表。
· 403.15 - 超出用戶端訪問許可。
· 403.16 - 用戶端認證不受信任或無效。
· 403.17 - 用戶端認證已到期或尚未生效。
· 403.18 - 在當前的應用程式集區中不能執行所請求的 URL。這個錯誤碼為 IIS 6.0 所專用。
· 403.19 - 不能為這個應用程式集區中的用戶端執行 CGI。這個錯誤碼為 IIS 6.0 所專用。
· 403.20 - Passport 登入失敗。這個錯誤碼為 IIS 6.0 所專用。
· 404 - Not Found 無法找到指定位置的資源。這也是一個常用的應答。
· 404.0 -(無) – 沒有找到檔案或目錄。
· 404.1 - 無法在所請求的連接埠上訪問 Web 網站。
· 404.2 - Web 服務擴充鎖定策略阻止本請求。
· 404.3 - MIME 對應策略阻止本請求。
· 405 - Method Not Allowed 要求方法(GET、POST、HEAD、DELETE、PUT、TRACE等)對指定的資源不適用,用來訪問本頁面的 HTTP 謂詞不被允許(方法不被允許)(HTTP 1.1

新)
· 406 - Not Acceptable 指定的資源已經找到,但它的MIME類型和客戶在Accpet頭中所指定的不相容,用戶端瀏覽器不接受所請求頁面的 MIME 類型(HTTP 1.1新)。
· 407 - Proxy Authentication Required 要求進行Proxy 驗證,類似於401,表示客戶必須先經過Proxy 伺服器的授權。(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新)。
· 415 – 不支援的媒體類型。
· 416 – Requested Range Not Satisfiable 伺服器不能滿足客戶在請求中指定的Range頭。(HTTP 1.1新) · 417 – 執行失敗。
· 423 – 鎖定的錯誤。

5xx - 伺服器錯誤
伺服器由於遇到錯誤而不能完成該請求。

· 500 - Internal Server Error 伺服器遇到了意料不到的情況,不能完成客戶的請求。
· 500.12 - 應用程式正忙於在 Web 服務器上重新啟動。
· 500.13 - Web 服務器太忙。
· 500.15 - 不允許直接請求 Global.asa。
· 500.16 – UNC 授權憑據不正確。這個錯誤碼為 IIS 6.0 所專用。
· 500.18 – URL 授權存放區不能開啟。這個錯誤碼為 IIS 6.0 所專用。
· 500.100 - 內部 ASP 錯誤。
· 501 - Not Implemented 伺服器不支援實現請求所需要的功能,頁首值指定了未實現的配置。例如,客戶發出了一個伺服器不支援的PUT請求。
· 502 - Bad Gateway 伺服器作為網關或者代理時,為了完成請求訪問下一個伺服器,但該伺服器返回了非法的應答。 亦說Web 服務器用作網關或Proxy 伺服器時收到了無效響應


· 502.1 - CGI 應用程式逾時。
· 502.2 - CGI 應用程式出錯。
· 503 - Service Unavailable 服務不可用,伺服器由於維護或者負載過重未能應答。例如,Servlet可能在資料庫連接池已滿的情況下返回503。伺服器返回503時可以提供一個

Retry-After頭。這個錯誤碼為 IIS 6.0 所專用。
· 504 - Gateway Timeout 網關逾時,由作為代理或網關的伺服器使用,表示不能及時地從遠程伺服器獲得應答。(HTTP 1.1新) 。
· 505 - HTTP Version Not Supported 伺服器不支援要求中所指明的HTTP版本。(HTTP 1.1新)

----下面是判斷是否是圖片,而返回的狀態代碼!------try            {                System.Drawing.Image img = System.Drawing.Image.FromStream(postedFile.InputStream);                postedFile.SaveAs(savepath + @"\" + sNewFileName + sExtension);                context.Response.Write(tempPath + sNewFileName + sExtension);                context.Response.StatusCode = 200;            }            catch (ArgumentException ex)            {                context.Response.Write(ex.Message);                context.Response.StatusCode = 403;            } 

 

常見的HTTP狀態代碼(HTTP Status Code)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.