100 Continue
5 B$ d6 u, `0 L ^初始的請求已經接受,客戶應當繼續發送請求的其餘部分
. |1 J& x* h5 o' V7 w
& v* v+ o! A- i N) A# B" _2 B101 Switching Protocols
2 x$ {/ J. R/ J1 v# e服務器將遵從客戶的請求轉換到另外一種協議
, @1 X1 J* i7 J" q6 N
* n( I% I3 V3 J0 C$ |* C N200 OK$ j: ]2 q/ p; I- b+ ]( q
一切正常,對GET和POST請求的應答文檔跟在後面. O p3 W ]' M" A5 ^+ U1 U
/ v3 G/ ^6 R% d) i# D& n) s( @* j
201 Created
h3 J9 [- T% k. u服務器已經創建了文檔,Location頭給出了它的URL。
% u h3 A+ Z/ @" R( C( M, |
9 K, D% [9 } A% r: B202 Accepted9 [/ j( }& _% d* D% s3 K: c) Y
已經接受請求,但處理尚未完成。
* l1 d( x, k8 w# n3 b- n% }5 } o( s; w5 C9 z3 w
203 Non-Authoritative Information. p2 M1 d5 \/ V2 C1 o
文檔已經正常地返回,但一些應答頭可能不正確,因為使用的是文檔的拷貝
, p. {% _+ W. U' x+ Z6 w: v( q. S- E" A- C7 I9 g+ Q0 d
204 No Content& k6 v- H7 A7 p2 g
沒有新文檔,瀏覽器應該繼續顯示原來的文檔。如果用戶定期地玩新頁面,而Servlet可以確定用戶文檔足夠新,這個狀態代碼是很有用的
% H' D/ w$ t3 `9 R; r* ^/ O4 u
* z" ~( z$ L3 y; y205 Reset Content
( D/ g/ T+ T4 G: e2 @沒有新的內容,但瀏覽器應該重置它所顯示的內容。用來強制瀏覽器清除表單輸入內容
; O2 s. B8 c; G( ]2 ~- G! Y* [& `3 f: T
206 Partial Content$ O, Y& O, `6 b T
客戶發送了一個帶有Range頭的GET請求,服務器完成了它8 B( ~5 w' A# n( ?% G7 p9 ]
3 v- J# r6 a" d- R$ G! S
300 Multiple Choices
3 V, s3 N% Y- O' d* E0 e3 T/ y客戶請求的文檔可以在多個位置找到,這些位置已經在返回的文檔內列出。如果服務器要提出優先選擇,則應該在Location應答頭指明。 q# \' Z- x l( r& e- f
2 C$ M2 y! z+ D! |! v
301 Moved Permanently: K- b6 e( C. g! B4 p
客戶請求的文檔在其他地方,新的URL在Location頭中給出,瀏覽器應該自動地訪問新的URL。( `, k/ x. p% F+ y
1 t' R; \' j9 n! }" c1 y302 Found. V8 q, a7 R4 @5 j/ P
類似於301,但新的URL應該被視為臨時性的替代,而不是永久性的。8 W6 L9 i+ t" N5 H3 |3 w
0 F A# c. j5 r* G! s303 See Other% P3 O- o, Z& v( E! J; u. y
類似於301/302,不同之處在於,如果原來的請求是POST,Location頭指定的重定向目標文檔應該通過GET提取
# ~" a4 `1 s1 F" B" v5 g( O& p* _- N# t# H& V/ Y: [
304 Not Modified
8 n0 j8 e2 g) t/ c- {客戶端有緩衝的文檔並發出了一個條件性的請求(一般是提供If-Modified-Since頭表示客戶只想比指定日期更新的文檔)。服務器告訴客戶,原來緩衝的文檔還可以繼續使用。) }" G- ?& y! `, D# @ @
( s2 F- G1 n1 U305 Use Proxy
7 _, U9 ?. M5 h9 H {客戶請求的文檔應該通過Location頭所指明的代理服務器提取& `9 q6 Q$ b# b% x8 y
) \. B: o* {+ `
307 Temporary Redirect
5 j0 }0 r' @5 @; v9 C和302(Found)相同。許多瀏覽器會錯誤地響應302應答進行重定向,即使原來的請求是 POST,即使它實際上只能在POST請求的應答是303時才能重定向。由於這個原因,HTTP 1.1新增了307,以便更加清除地區分幾個狀態代碼: 當出現303應答時,瀏覽器可以跟隨重定向的GET和POST請求;如果是307應答,則瀏覽器只能跟隨對GET請求的重定向。
! g+ P7 E$ }7 e! F5 a. \" f0 [* h5 J4 K- |. {' \' S% o% N6 S
400 Bad Request
+ s. `$ t# P" @請求出現語法錯誤。
+ z, {: H% ] h+ m: ?
0 J7 C7 j3 ?& v* m: d& N( ~401 Unauthorized
" \) h0 W" R" H8 _ t. k客戶試圖未經授權訪問受密碼保護的頁面。應答中會包含一個WWW-Authenticate頭,瀏覽器據此顯示用戶名字/密碼對話框,然後在填寫合適的Authorization頭後再次發出請求。
) B# ~2 I6 k" M% M. Q+ Q. j3 h0 r) ^
, C( ]/ q- C# ]403 Forbidden- j) c9 x7 C7 ~( O
資源不可用。/ @& O* ?; U/ v$ r% D; X& {( ?! V
3 L( [5 ]; o8 d) s4 o$ U2 G404 Not Found/ d% f; c. m9 o/ D
無法找到指定位置的資源
$ A, `5 ^( g0 `$ I( }0 G5 K9 F5 w1 C. N
405 Method Not Allowed" j; b r* i# o3 v
請求方法(GET、POST、HEAD、Delete、PUT、TRACE等)對指定的資源不適用。0 U0 [9 A# F) q: c
0 a+ ?# Z8 j$ x& t! |
406 Not Acceptable
9 m! k* H$ B" I9 g+ z5 d指定的資源已經找到,但它的MIME類型和客戶在Accpet頭中所指定的不兼容
' w, V. E9 z& D: E' m2 Q+ m0 ^4 J- P- `- Q5 [# x$ c
407 Proxy Authentication Required1 z! x) T: x, e3 W2 Z3 k" P
類似於401,表示客戶必須先經過代理服務器的授權。
' L2 h) ] a3 {* F/ ]: W7 u1 D% B _: I. p4 ^, @9 F! L
408 Request Timeout% _3 b4 B3 K1 E: x3 Z- l) U
在服務器許可的等待時間內,客戶一直沒有發出任何請求。客戶可以在以後重複同一請求。
# E5 W- y$ v+ [# V0 A) N! H# C: h8 ?& t7 O* N( B
409 Conflict
+ C, o: L# q2 b, A通常和PUT請求有關。由於請求和資源的當前狀態相衝突,因此請求不能成功。
% y& a' C) W+ v4 J/ W3 E
- E8 Y( r& I, ^/ w410 Gone3 y/ g, L5 |3 c9 V9 x/ @
所請求的文檔已經不再可用,而且服務器不知道應該重定向到哪一個地址。它和404的不同在於,返回407表示文檔永久地離開了指定的位置,而404表示由於未知的原因文檔不可用。. a/ w& Y4 M. s: Y- ]* K
* R6 g$ H$ F) T9 ?: J3 i
411 Length Required
& R& X( u0 _: h5 V6 M0 U服務器不能處理請求,除非客戶發送一個Content-Length頭。
0 a' k3 E# I7 J" @) W, x* V; m) p7 L. U8 I& M, q: K- V
412 Precondition Failed
M' @) \+ C, K0 ^, j& c. M7 ^請求頭中指定的一些前提條件失敗7 k/ k2 S+ a4 j& n
; n' u1 A1 x7 a1 v7 i6 Y/ p
413 Request Entity Too Large5 `+ |* I' d+ G k0 ?- ]
目標文檔的大小超過服務器當前願意處理的大小。如果服務器認為自己能夠稍後再處理該請求,則應該提供一個Retry-After頭
+ F. S( _- G3 `8 p% I( r
+ _7 v5 U6 Z. a2 X' m' Q414 Request URI Too Long
$ Q% U) P1 c, ]. k. w1 J6 nURI太長
9 ^1 _. Y9 R( B ^$ B3 S2 _
7 J+ R. M/ D0 v3 j, K. P: r416 Requested Range Not Satisfiable8 T) a- z0 Y- W% d
服務器不能滿足客戶在請求中指定的Range頭; g0 \+ O4 Z: ?/ e' g/ d
H* @/ w( i$ h, P; r/ H
500 Internal Server Error; Y1 C* @+ N9 R6 m7 I, Z# ^) G
服務器遇到了意料不到的情況,不能完成客戶的請求
0 Y# C; {. z, c2 _1 g" c: P8 O# k. u% U ?& r. g
501 Not Implemented
$ j1 }* h0 D( b- m& R8 l7 l7 e服務器不支持實現請求所需要的功能。例如,客戶發出了一個服務器不支持的PUT請求& G, @5 p, W' _3 a/ f
0 s: M& Y1 {: h# Z1 y502 Bad Gateway. O# `) o" X/ x$ J9 g$ t4 T# d
服務器作為網關或者代理時,為了完成請求訪問下一個服務器,但該服務器返回了非法的應答
6 |6 }( N7 S- v( i' `! ]3 @ t
4 V* s6 @* v; a+ T2 u503 Service Unavailable
# Q4 M, Q& b* g' c6 M; R服務器由於維護或者負載過重未能應答。例如,Servlet可能在數據庫連接池已滿的情況下返回503。服務器返回503時可以提供一個Retry-After頭
7 j# S" v. g9 J1 d2 u
" Y; b# h1 j; c/ r1 |504 Gateway Timeout# ]" J+ P! Y; Q( o
由作為代理或網關的服務器使用,表示不能及時地從遠程服務器獲得應答+ T5 V, K# B6 {% i: [7 z$ `- E
' m3 c0 k! J# L- k) o* f6 j& l
505 HTTP Version Not Supported1 z) k2 U* m7 d! Q: C
服務器不支持請求中所指明的HTTP版本 |
|