摘要
本文部分內容來源於網絡,個人收集整理,請勿傳播
所有 HTTP 狀態代碼及其定義。
本文內容取自網絡。
2xx 成功
1 2 3 4 5 6
|
2xx 成功 200 正常;請求已完成。 201 正常;緊接 POST 命令。 202 正常;已接受用於處理,但處理尚未完成。 203 正常;部分信息 — 返回的信息只是一部分。 204 正常;無響應 — 已接收請求,但不存在要回送的信息。
|
3xx 重定向
301 && 302
- 301 永久重定向
- Moved Permanently 被請求的資源已永久移動到新位置,並且將來任何對此資源的引用都應該使用本響應返回的若干個URI之一。如果可能,擁有鏈接編輯功能的客戶端應當自動把請求的地址修改為從服務器反饋回來的地址。除非額外指定,否則這個響應也是可緩存的。
- 302 臨時重定向
- Found 請求的資源現在臨時從不同的URI響應請求。由於這樣的重定向是臨時的,客戶端應當繼續向原有地址發送以后的請求。只有在Cache-Control或Expires中進行了指定的情況下,這個響應才是可緩存的。
- 共同點:用戶都可以看到url替換為了一個新的,然后發出請求
301適合永久重定向
注意: 301請求是可以緩存的, 即通過看status code,可以發現后面寫着from cache。
302用來做臨時跳轉
- 比如未登陸的用戶訪問用戶中心重定向到登錄頁面。
- 訪問404頁面會重新定向到首頁。
304
客戶端發送了一個帶條件的GET請求且該請求已被允許,但是請求的文檔沒有發生改變,則狀態碼是304
1 2 3
|
303 請參閱其它 — 可在另一 URI 下找到對請求的響應,且應使用 GET 方法檢索此響應。 305 使用代理 — 必須通過位置字段中提供的代理來訪問請求的資源。 306 未使用 — 不再使用;保留此代碼以便將來使用。
|
4xx 客戶端錯誤
1 2 3 4 5 6 7 8 9 10
|
400 錯誤請求 — 請求中有語法問題,或不能滿足請求。 401 未授權 — 未授權客戶機訪問數據。 402 需要付款 — 表示計費系統已有效。 403 禁止訪問,服務器找到了訪問的資源但是沒有權限訪問 404 Not Found 服務器找不到訪問的資源 407 代理認證請求 — 客戶機首先必須使用代理認證自身。 410 - 永遠不可用 412 - 先決條件失敗 414 - 請求 - URI 太長 415 介質類型不受支持 — 服務器拒絕服務請求,因為不支持請求實體的格式。
|
499
499錯誤是什么?讓我們看看NGINX的源碼中的定義:
1 2 3 4 5
|
ngx_string(ngx_http_error_495_page), /* 495, https certificate error */ ngx_string(ngx_http_error_496_page), /* 496, https no certificate */ ngx_string(ngx_http_error_497_page), /* 497, http to https */ ngx_string(ngx_http_error_404_page), /* 498, canceled */ ngx_null_string, /* 499, client has closed connection */
|
可以看到,499對應的是 “client has closed connection”。這很有可能是因為服務器端處理的時間過長,客戶端“不耐煩”了。
- nginx發現如果兩次提交post過快就會出現499的情況,看來是nginx認為是不安全的連接,主動拒絕了客戶端的連接.
- nginx轉發php或者另一個nginx,超時時間比后端程序短,達到了超時時間會主動斷開客戶端的連接,返回499
1 2 3
|
# nginx 添加以下參數 # 表示代理服務端不要主要主動關閉客戶端連接 proxy_ignore_client_abort on;
|
5xx 服務器中出現的錯誤
1 2 3 4 5
|
500 內部錯誤 - 代碼因為意外(報錯)無法返回請求結果 501 服務器無法理解,或者不支持http請求中的方法 502 Bad Gateway 網關錯誤 — 服務器接收到來自上游服務器的無效響應。 503 無法獲得服務 — 由於臨時過載或維護,服務器無法處理請求。 504 網關超時
|
其他
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
|
HTTP狀態代碼(各種錯誤代碼集合) 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新)
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 |