亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁(yè) > 課堂 > 網(wǎng)絡(luò)協(xié)議 > 正文

前端開(kāi)發(fā)者必須知道的http協(xié)議相關(guān)知識(shí)

2020-03-24 16:30:27
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

http(超文本傳輸協(xié)議)是一個(gè)基于請(qǐng)求與響應(yīng)模式的、無(wú)狀態(tài)的、應(yīng)用層的協(xié)議,常基于TCP的連接方式。本文講述的是前端開(kāi)發(fā)者必須知道的http協(xié)議相關(guān)知識(shí),做想做前端和正在做前端的小伙伴一定要知道哦。

1.概念

http(超文本傳輸協(xié)議)是一個(gè)基于請(qǐng)求與響應(yīng)模式的、無(wú)狀態(tài)的、應(yīng)用層的協(xié)議,?;赥CP的連接方式,HTTP1.1版本中給出一種持續(xù)連接的機(jī)制,絕大多數(shù)的Web開(kāi)發(fā),都是構(gòu)建在HTTP協(xié)議之上的Web應(yīng)用。

2.發(fā)展

0.9版本(只支持get)——1.0——1.1——2.0(開(kāi)發(fā)中)

0.9版本只能算是試用版,不做介紹。主要講講1.0和1.1的區(qū)別。

2.1 持續(xù)連接和非持續(xù)連接

1.0版本支持非持久連接,也就是說(shuō)經(jīng)過(guò)tcp協(xié)議(http是基于TCP的應(yīng)用層協(xié)議)三次握手建立連接后,服務(wù)端只能發(fā)送一個(gè)對(duì)象給瀏覽器,然后鏈接即斷開(kāi),如果網(wǎng)頁(yè)中包含其他內(nèi)聯(lián)對(duì)象,如圖片,html' target='_blank'>js文件,css文件等,則需要建立多次鏈接,這其中就會(huì)導(dǎo)致多次建立/斷開(kāi)連接的開(kāi)銷。而1.1版本則支持持續(xù)鏈接,一個(gè)連接建立后,可以發(fā)送多個(gè)對(duì)象,因而在理論上,1.1版本要比1.0更節(jié)約資源,更快,但也有網(wǎng)友表示1.0反而要快一些,這就不得而知了。

2.2 Host域

Host頭域指定請(qǐng)求資源的Intenet主機(jī)和端口號(hào),必須表示請(qǐng)求url的原始服務(wù)器或網(wǎng)關(guān)的位置。HTTP/1.1請(qǐng)求必須包含主機(jī)頭域,否則系統(tǒng)會(huì)以400狀態(tài)碼返回。這個(gè)域感覺(jué)可有可無(wú),也許是為了提高速度吧。畢竟直接指定HOST,能更快找到對(duì)應(yīng)主機(jī),如果該主機(jī)不存在,也能更快發(fā)現(xiàn)。

2.3 帶寬優(yōu)化

1.1版本支持資源部分請(qǐng)求,可以只請(qǐng)求資源的一部分。同時(shí),1.1版本支持100狀態(tài)碼,當(dāng)請(qǐng)求實(shí)體較大時(shí),可以先發(fā)送帶有100狀態(tài)碼的頭域,先確認(rèn)服務(wù)端是否響應(yīng)該請(qǐng)求,如果能響應(yīng),則再次發(fā)送請(qǐng)求實(shí)體,從而在某些無(wú)法響應(yīng)的情況下節(jié)省帶寬。

具體流程:客戶端——發(fā)送帶有100狀態(tài)碼的請(qǐng)求頭——服務(wù)端確認(rèn)是否能響應(yīng),如果不能,返回相應(yīng)狀態(tài)碼(如401,未認(rèn)證),如果能,則返回100狀態(tài)碼——客戶端根據(jù)返回狀態(tài)碼,確認(rèn)是否繼續(xù)發(fā)送請(qǐng)求。

2.4 請(qǐng)求方法與狀態(tài)碼

HTTP1.1增加了OPTIONS, PUT, DELETE, TRACE, CONNECT這些Request方法

HTTP/1.0中只定義了16個(gè)狀態(tài)響應(yīng)碼,對(duì)錯(cuò)誤或警告的提示不夠具體。HTTP/1.1引入了一個(gè)Warning頭域,增加對(duì)錯(cuò)誤或警告信息的描述。

在HTTP/1.1中新增了24個(gè)狀態(tài)響應(yīng)碼,如409(Conflict)表示請(qǐng)求的資源與資源的當(dāng)前狀態(tài)發(fā)生沖突;410(Gone)表示服務(wù)器上的某個(gè)資源被永久性的刪除。

3.http通信過(guò)程

(1)根據(jù)URL查詢DNS,查找web服務(wù)器,并與之建立tcp連接(http下層的協(xié)議)。

(2)隨后web瀏覽器向服務(wù)器發(fā)送請(qǐng)求。

請(qǐng)求一般包括:|請(qǐng)求方法 uri http版本號(hào) |請(qǐng)求頭 |請(qǐng)求正文 舉例:

GET /hello.jpg HTTP/1.1

Accept:image/gif.image/jpeg

Accept-Language:zh-cn

Connection:Keep-Alive

Host:127.0.0.1

User-Agent:Mozila/4.0(compatible;MSIE5.01;Window NT5.0)

Accept-Encoding:gzip,deflate

(3)web服務(wù)器響應(yīng)。響應(yīng)包一般包括: |協(xié)議版本 狀態(tài)碼 描述 |響應(yīng)頭 |響應(yīng)正文

HTTP/1.1 200 OK

Server:Apache Tomcat/5.0.12

Date:Mon,6 Oct 2017 13:23:42 GMT

Content-Length:188

4. http頭域

這部分內(nèi)容太細(xì)太多,直接上表。

請(qǐng)求頭:

Header解釋示例Accept指定客戶端能夠接收的內(nèi)容類型Accept: text/plain, text/htmlAccept-Charset瀏覽器可以接受的字符編碼集。Accept-Charset: iso-8859-5Accept-Encoding指定瀏覽器可以支持的web服務(wù)器返回內(nèi)容壓縮編碼類型。Accept-Encoding: compress, gzipAccept-Language瀏覽器可接受的語(yǔ)言Accept-Language: en,zhAccept-Ranges可以請(qǐng)求網(wǎng)頁(yè)實(shí)體的一個(gè)或者多個(gè)子范圍字段Accept-Ranges: bytesAuthorizationHTTP授權(quán)的授權(quán)證書Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==Cache-Control指定請(qǐng)求和響應(yīng)遵循的緩存機(jī)制Cache-Control: no-cacheConnection表示是否需要持久連接。(HTTP 1.1默認(rèn)進(jìn)行持久連接)Connection: closeCookieHTTP請(qǐng)求發(fā)送時(shí),會(huì)把保存在該請(qǐng)求域名下的所有cookie值一起發(fā)送給web服務(wù)器。Cookie: $Version=1; Skin=new;Content-Length請(qǐng)求的內(nèi)容長(zhǎng)度Content-Length: 348Content-Type請(qǐng)求的與實(shí)體對(duì)應(yīng)的MIME信息Content-Type: application/x-www-form-urlencodedDate請(qǐng)求發(fā)送的日期和時(shí)間Date: Tue, 15 Nov 2010 08:12:31 GMTExpect請(qǐng)求的特定的服務(wù)器行為Expect: 100-continueFrom發(fā)出請(qǐng)求的用戶的EmailFrom: user@email.comHost指定請(qǐng)求的服務(wù)器的域名和端口號(hào)Host: www.zcmhi.comIf-Match只有請(qǐng)求內(nèi)容與實(shí)體相匹配才有效If-Match: “737060cd8c284d8af7ad3082f209582d”If-Modified-Since如果請(qǐng)求的部分在指定時(shí)間之后被修改則請(qǐng)求成功,未被修改則返回304代碼If-Modified-Since: Sat, 29 Oct 2010 19:43:31 GMTIf-None-Match如果內(nèi)容未改變返回304代碼,參數(shù)為服務(wù)器先前發(fā)送的Etag,與服務(wù)器回應(yīng)的Etag比較判斷是否改變If-None-Match: “737060cd8c284d8af7ad3082f209582d”If-Range如果實(shí)體未改變,服務(wù)器發(fā)送客戶端丟失的部分,否則發(fā)送整個(gè)實(shí)體。參數(shù)也為EtagIf-Range: “737060cd8c284d8af7ad3082f209582d”If-Unmodified-Since只在實(shí)體在指定時(shí)間之后未被修改才請(qǐng)求成功If-Unmodified-Since: Sat, 29 Oct 2010 19:43:31 GMTMax-Forwards限制信息通過(guò)代理和網(wǎng)關(guān)傳送的時(shí)間Max-Forwards: 10Pragma用來(lái)包含實(shí)現(xiàn)特定的指令Pragma: no-cacheProxy-Authorization連接到代理的授權(quán)證書Proxy-Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==Range只請(qǐng)求實(shí)體的一部分,指定范圍Range: bytes=500-999Referer先前網(wǎng)頁(yè)的地址,當(dāng)前請(qǐng)求網(wǎng)頁(yè)緊隨其后,即來(lái)路Referer: http://www.zcmhi.com/archives/71.htmlTE客戶端愿意接受的傳輸編碼,并通知服務(wù)器接受接受尾加頭信息TE: trailers,deflate;q=0.5Upgrade向服務(wù)器指定某種傳輸協(xié)議以便服務(wù)器進(jìn)行轉(zhuǎn)換(如果支持)Upgrade: HTTP/2.0, SHTTP/1.3, IRC/6.9, RTA/x11User-AgentUser-Agent的內(nèi)容包含發(fā)出請(qǐng)求的用戶信息User-Agent: Mozilla/5.0 (Linux; X11)Via通知中間網(wǎng)關(guān)或代理服務(wù)器地址,通信協(xié)議Via: 1.0 fred, 1.1 nowhere.com (Apache/1.1)Warning關(guān)于消息實(shí)體的警告信息Warn: 199 Miscellaneous warning


響應(yīng)頭:

Header解釋示例Accept-Ranges表明服務(wù)器是否支持指定范圍請(qǐng)求及哪種類型的分段請(qǐng)求Accept-Ranges: bytesAge從原始服務(wù)器到代理緩存形成的估算時(shí)間(以秒計(jì),非負(fù))Age: 12Allow對(duì)某網(wǎng)絡(luò)資源的有效的請(qǐng)求行為,不允許則返回405Allow: GET, HEADCache-Control告訴所有的緩存機(jī)制是否可以緩存及哪種類型Cache-Control: no-cacheContent-Encodingweb服務(wù)器支持的返回內(nèi)容壓縮編碼類型。Content-Encoding: gzipContent-Language響應(yīng)體的語(yǔ)言Content-Language: en,zhContent-Length響應(yīng)體的長(zhǎng)度Content-Length: 348Content-Location請(qǐng)求資源可替代的備用的另一地址Content-Location: /index.htmContent-MD5返回資源的MD5校驗(yàn)值Content-MD5: Q2hlY2sgSW50ZWdyaXR5IQ==Content-Range在整個(gè)返回體中本部分的字節(jié)位置Content-Range: bytes 21010-47021/47022Content-Type返回內(nèi)容的MIME類型Content-Type: text/html; charset=utf-8Date原始服務(wù)器消息發(fā)出的時(shí)間Date: Tue, 15 Nov 2010 08:12:31 GMTETag請(qǐng)求變量的實(shí)體標(biāo)簽的當(dāng)前值ETag: “737060cd8c284d8af7ad3082f209582d”Expires響應(yīng)過(guò)期的日期和時(shí)間Expires: Thu, 01 Dec 2010 16:00:00 GMTLast-Modified請(qǐng)求資源的最后修改時(shí)間Last-Modified: Tue, 15 Nov 2010 12:45:26 GMTLocation用來(lái)重定向接收方到非請(qǐng)求URL的位置來(lái)完成請(qǐng)求或標(biāo)識(shí)新的資源Location: http://www.zcmhi.com/archives/94.htmlPragma包括實(shí)現(xiàn)特定的指令,它可應(yīng)用到響應(yīng)鏈上的任何接收方Pragma: no-cacheProxy-Authenticate它指出認(rèn)證方案和可應(yīng)用到代理的該URL上的參數(shù)Proxy-Authenticate: Basicrefresh應(yīng)用于重定向或一個(gè)新的資源被創(chuàng)造,在5秒之后重定向(由網(wǎng)景提出,被大部分瀏覽器支持)

Refresh: 5; url=

http://www.zcmhi.com/archives/94.html

Retry-After如果實(shí)體暫時(shí)不可取,通知客戶端在指定時(shí)間之后再次嘗試Retry-After: 120Serverweb服務(wù)器軟件名稱Server: Apache/1.3.27 (Unix) (Red-Hat/Linux)Set-Cookie設(shè)置Http CookieSet-Cookie: UserID=JohnDoe; Max-Age=3600; Version=1Trailer指出頭域在分塊傳輸編碼的尾部存在Trailer: Max-ForwardsTransfer-Encoding文件傳輸編碼Transfer-Encoding:chunkedVary告訴下游代理是使用緩存響應(yīng)還是從原始服務(wù)器請(qǐng)求Vary: *Via告知代理客戶端響應(yīng)是通過(guò)哪里發(fā)送的Via: 1.0 fred, 1.1 nowhere.com (Apache/1.1)Warning警告實(shí)體可能存在的問(wèn)題Warning: 199 Miscellaneous warningWWW-Authenticate表明客戶端請(qǐng)求實(shí)體應(yīng)該使用的授權(quán)方案WWW-Authenticate: Basic

5. http request方法

GET 請(qǐng)求獲取Request-URI所標(biāo)識(shí)的資源
POST 在Request-URI所標(biāo)識(shí)的資源后附加新的數(shù)據(jù)
HEAD 請(qǐng)求獲取由Request-URI所標(biāo)識(shí)的資源的響應(yīng)消息報(bào)頭
PUT 請(qǐng)求服務(wù)器存儲(chǔ)一個(gè)資源,并用Request-URI作為其標(biāo)識(shí)
DELETE 請(qǐng)求服務(wù)器刪除Request-URI所標(biāo)識(shí)的資源
TRACE 請(qǐng)求服務(wù)器回送收到的請(qǐng)求信息,主要用于測(cè)試或診斷
CONNECT 保留將來(lái)使用
OPTIONS 請(qǐng)求查詢服務(wù)器的性能,或者查詢與資源相關(guān)的選項(xiàng)和需求

6. 狀態(tài)碼

Response 消息中的第一行叫做狀態(tài)行,由HTTP協(xié)議版本號(hào), 狀態(tài)碼, 狀態(tài)消息 三部分組成。

狀態(tài)碼用來(lái)告訴HTTP客戶端,HTTP服務(wù)器是否產(chǎn)生了預(yù)期的Response.

HTTP/1.1中定義了5類狀態(tài)碼, 狀態(tài)碼由三位數(shù)字組成,第一個(gè)數(shù)字定義了響應(yīng)的類別

1XX 提示信息 - 表示請(qǐng)求已被成功接收,繼續(xù)處理,表示還需要繼續(xù)接受數(shù)據(jù)才能完成請(qǐng)求的意思。

2XX 成功 - 表示請(qǐng)求已被成功接收,理解,接受

3XX 重定向 - 要完成請(qǐng)求必須進(jìn)行更進(jìn)一步的處理

4XX 客戶端錯(cuò)誤 - 請(qǐng)求有語(yǔ)法錯(cuò)誤或請(qǐng)求無(wú)法實(shí)現(xiàn)

5XX 服務(wù)器端錯(cuò)誤 - 服務(wù)器未能實(shí)現(xiàn)合法的請(qǐng)求

狀態(tài)嗎碼大全

表1(簡(jiǎn)單介紹表,介紹簡(jiǎn)介簡(jiǎn)潔清晰,推薦先查看此表,如有不懂,再查看下面的表2)

狀態(tài)碼狀態(tài)碼英文名稱中文描述1開(kāi)頭的狀態(tài)碼100Continue繼續(xù)。客戶端應(yīng)繼續(xù)其請(qǐng)求101Switching Protocols切換協(xié)議。服務(wù)器根據(jù)客戶端的請(qǐng)求切換協(xié)議。只能切換到更高級(jí)的協(xié)議,例如,切換到HTTP的新版本協(xié)議2開(kāi)頭的狀態(tài)碼200OK請(qǐng)求成功。一般用于GET與POST請(qǐng)求201Created已創(chuàng)建。成功請(qǐng)求并創(chuàng)建了新的資源202Accepted已接受。已經(jīng)接受請(qǐng)求,但未處理完成203Non-Authoritative Information非授權(quán)信息。請(qǐng)求成功。但返回的meta信息不在原始的服務(wù)器,而是一個(gè)副本204No Content無(wú)內(nèi)容。服務(wù)器成功處理,但未返回內(nèi)容。在未更新網(wǎng)頁(yè)的情況下,可確保瀏覽器繼續(xù)顯示當(dāng)前文檔205Reset Content重置內(nèi)容。服務(wù)器處理成功,用戶終端(例如:瀏覽器)應(yīng)重置文檔視圖??赏ㄟ^(guò)此返回碼清除瀏覽器的表單域206Partial Content部分內(nèi)容。服務(wù)器成功處理了部分GET請(qǐng)求3開(kāi)頭的狀態(tài)碼300Multiple Choices多種選擇。請(qǐng)求的資源可包括多個(gè)位置,相應(yīng)可返回一個(gè)資源特征與地址的列表用于用戶終端(例如:瀏覽器)選擇301Moved Permanently永久移動(dòng)。請(qǐng)求的資源已被永久的移動(dòng)到新URI,返回信息會(huì)包括新的URI,瀏覽器會(huì)自動(dòng)定向到新URI。今后任何新的請(qǐng)求都應(yīng)使用新的URI代替302Found臨時(shí)移動(dòng)。與301類似。但資源只是臨時(shí)被移動(dòng)??蛻舳藨?yīng)繼續(xù)使用原有URI303See Other查看其它地址。與301類似。使用GET和POST請(qǐng)求查看304Not Modified未修改。所請(qǐng)求的資源未修改,服務(wù)器返回此狀態(tài)碼時(shí),不會(huì)返回任何資源??蛻舳送ǔ?huì)緩存訪問(wèn)過(guò)的資源,通過(guò)提供一個(gè)頭信息指出客戶端希望只返回在指定日期之后修改的資源305Use Proxy使用代理。所請(qǐng)求的資源必須通過(guò)代理訪問(wèn)306Unused已經(jīng)被廢棄的HTTP狀態(tài)碼307Temporary Redirect臨時(shí)重定向。與302類似。使用GET請(qǐng)求重定向4開(kāi)頭的狀態(tài)碼400Bad Request客戶端請(qǐng)求的語(yǔ)法錯(cuò)誤,服務(wù)器無(wú)法理解401Unauthorized請(qǐng)求要求用戶的身份認(rèn)證402Payment Required保留,將來(lái)使用403Forbidden服務(wù)器理解請(qǐng)求客戶端的請(qǐng)求,但是拒絕執(zhí)行此請(qǐng)求404Not Found服務(wù)器無(wú)法根據(jù)客戶端的請(qǐng)求找到資源(網(wǎng)頁(yè))。通過(guò)此代碼,網(wǎng)站設(shè)計(jì)人員可設(shè)置 您所請(qǐng)求的資源無(wú)法找到 的個(gè)性頁(yè)面405Method Not Allowed客戶端請(qǐng)求中的方法被禁止406Not Acceptable服務(wù)器無(wú)法根據(jù)客戶端請(qǐng)求的內(nèi)容特性完成請(qǐng)求407Proxy Authentication Required請(qǐng)求要求代理的身份認(rèn)證,與401類似,但請(qǐng)求者應(yīng)當(dāng)使用代理進(jìn)行授權(quán)408Request Time-out服務(wù)器等待客戶端發(fā)送的請(qǐng)求時(shí)間過(guò)長(zhǎng),超時(shí)409Conflict服務(wù)器完成客戶端的PUT請(qǐng)求是可能返回此代碼,服務(wù)器處理請(qǐng)求時(shí)發(fā)生了沖突410Gone客戶端請(qǐng)求的資源已經(jīng)不存在。410不同于404,如果資源以前有現(xiàn)在被永久刪除了可使用410代碼,網(wǎng)站設(shè)計(jì)人員可通過(guò)301代碼指定資源的新位置411Length Required服務(wù)器無(wú)法處理客戶端發(fā)送的不帶Content-Length的請(qǐng)求信息412Precondition Failed客戶端請(qǐng)求信息的先決條件錯(cuò)誤413Request Entity Too Large由于請(qǐng)求的實(shí)體過(guò)大,服務(wù)器無(wú)法處理,因此拒絕請(qǐng)求。為防止客戶端的連續(xù)請(qǐng)求,服務(wù)器可能會(huì)關(guān)閉連接。如果只是服務(wù)器暫時(shí)無(wú)法處理,則會(huì)包含一個(gè)Retry-After的響應(yīng)信息414Request-URI Too Large請(qǐng)求的URI過(guò)長(zhǎng)(URI通常為網(wǎng)址),服務(wù)器無(wú)法處理415Unsupported Media Type服務(wù)器無(wú)法處理請(qǐng)求附帶的媒體格式416Requested range not satisfiable客戶端請(qǐng)求的范圍無(wú)效417Expectation Failed服務(wù)器無(wú)法滿足Expect的請(qǐng)求頭信息5開(kāi)頭的狀態(tài)碼500Internal Server Error服務(wù)器內(nèi)部錯(cuò)誤,無(wú)法完成請(qǐng)求501Not Implemented服務(wù)器不支持請(qǐng)求的功能,無(wú)法完成請(qǐng)求502Bad Gateway充當(dāng)網(wǎng)關(guān)或代理的服務(wù)器,從遠(yuǎn)端服務(wù)器接收到了一個(gè)無(wú)效的請(qǐng)求503Service Unavailable由于超載或系統(tǒng)維護(hù),服務(wù)器暫時(shí)的無(wú)法處理客戶端的請(qǐng)求。延時(shí)的長(zhǎng)度可包含在服務(wù)器的Retry-After頭信息中504Gateway Time-out充當(dāng)網(wǎng)關(guān)或代理的服務(wù)器,未及時(shí)從遠(yuǎn)端服務(wù)器獲取請(qǐng)求505HTTP Version not supported服務(wù)器不支持請(qǐng)求的HTTP協(xié)議的版本,無(wú)法完成處理

表2 詳細(xì)介紹表

狀態(tài)碼含義100客戶端應(yīng)當(dāng)繼續(xù)發(fā)送請(qǐng)求。這個(gè)臨時(shí)響應(yīng)是用來(lái)通知客戶端它的部分請(qǐng)求已經(jīng)被服務(wù)器接收,且仍未被拒絕??蛻舳藨?yīng)當(dāng)繼續(xù)發(fā)送請(qǐng)求的剩余部分,或者如果請(qǐng)求已經(jīng)完成,忽略這個(gè)響應(yīng)。服務(wù)器必須在請(qǐng)求完成后向客戶端發(fā)送一個(gè)最終響應(yīng)。101服務(wù)器已經(jīng)理解了客戶端的請(qǐng)求,并將通過(guò)Upgrade 消息頭通知客戶端采用不同的協(xié)議來(lái)完成這個(gè)請(qǐng)求。在發(fā)送完這個(gè)響應(yīng)最后的空行后,服務(wù)器將會(huì)切換到在Upgrade 消息頭中定義的那些協(xié)議。 只有在切換新的協(xié)議更有好處的時(shí)候才應(yīng)該采取類似措施。例如,切換到新的HTTP 版本比舊版本更有優(yōu)勢(shì),或者切換到一個(gè)實(shí)時(shí)且同步的協(xié)議以傳送利用此類特性的資源。102由WebDAV(RFC 2518)擴(kuò)展的狀態(tài)碼,代表處理將被繼續(xù)執(zhí)行。200請(qǐng)求已成功,請(qǐng)求所希望的響應(yīng)頭或數(shù)據(jù)體將隨此響應(yīng)返回。201請(qǐng)求已經(jīng)被實(shí)現(xiàn),而且有一個(gè)新的資源已經(jīng)依據(jù)請(qǐng)求的需要而建立,且其 URI 已經(jīng)隨Location 頭信息返回。假如需要的資源無(wú)法及時(shí)建立的話,應(yīng)當(dāng)返回 202 Accepted 。202服務(wù)器已接受請(qǐng)求,但尚未處理。正如它可能被拒絕一樣,最終該請(qǐng)求可能會(huì)也可能不會(huì)被執(zhí)行。在異步操作的場(chǎng)合下,沒(méi)有比發(fā)送這個(gè)狀態(tài)碼更方便的做法了。 返回202狀態(tài)碼的響應(yīng)的目的是允許服務(wù)器接受其他過(guò)程的請(qǐng)求(例如某個(gè)每天只執(zhí)行一次的基于批處理的操作),而不必讓客戶端一直保持與服務(wù)器的連接直到批處理操作全部完成。在接受請(qǐng)求處理并返回202狀態(tài)碼的響應(yīng)應(yīng)當(dāng)在返回的實(shí)體中包含一些指示處理當(dāng)前狀態(tài)的信息,以及指向處理狀態(tài)監(jiān)視器或狀態(tài)預(yù)測(cè)的指針,以便用戶能夠估計(jì)操作是否已經(jīng)完成。203服務(wù)器已成功處理了請(qǐng)求,但返回的實(shí)體頭部元信息不是在原始服務(wù)器上有效的確定集合,而是來(lái)自本地或者第三方的拷貝。當(dāng)前的信息可能是原始版本的子集或者超集。例如,包含資源的元數(shù)據(jù)可能導(dǎo)致原始服務(wù)器知道元信息的超級(jí)。使用此狀態(tài)碼不是必須的,而且只有在響應(yīng)不使用此狀態(tài)碼便會(huì)返回200 OK的情況下才是合適的。204服務(wù)器成功處理了請(qǐng)求,但不需要返回任何實(shí)體內(nèi)容,并且希望返回更新了的元信息。響應(yīng)可能通過(guò)實(shí)體頭部的形式,返回新的或更新后的元信息。如果存在這些頭部信息,則應(yīng)當(dāng)與所請(qǐng)求的變量相呼應(yīng)。 如果客戶端是瀏覽器的話,那么用戶瀏覽器應(yīng)保留發(fā)送了該請(qǐng)求的頁(yè)面,而不產(chǎn)生任何文檔視圖上的變化,即使按照規(guī)范新的或更新后的元信息應(yīng)當(dāng)被應(yīng)用到用戶瀏覽器活動(dòng)視圖中的文檔。 由于204響應(yīng)被禁止包含任何消息體,因此它始終以消息頭后的第一個(gè)空行結(jié)尾。205服務(wù)器成功處理了請(qǐng)求,且沒(méi)有返回任何內(nèi)容。但是與204響應(yīng)不同,返回此狀態(tài)碼的響應(yīng)要求請(qǐng)求者重置文檔視圖。該響應(yīng)主要是被用于接受用戶輸入后,立即重置表單,以便用戶能夠輕松地開(kāi)始另一次輸入。 與204響應(yīng)一樣,該響應(yīng)也被禁止包含任何消息體,且以消息頭后的第一個(gè)空行結(jié)束。206服務(wù)器已經(jīng)成功處理了部分 GET 請(qǐng)求。類似于 FlashGet 或者迅雷這類的 HTTP 下載工具都是使用此類響應(yīng)實(shí)現(xiàn)斷點(diǎn)續(xù)傳或者將一個(gè)大文檔分解為多個(gè)下載段同時(shí)下載。 該請(qǐng)求必須包含 Range 頭信息來(lái)指示客戶端希望得到的內(nèi)容范圍,并且可能包含 If-Range 來(lái)作為請(qǐng)求條件。 響應(yīng)必須包含如下的頭部域: Content-Range 用以指示本次響應(yīng)中返回的內(nèi)容的范圍;如果是 Content-Type 為 multipart/byteranges 的多段下載,則每一 multipart 段中都應(yīng)包含 Content-Range 域用以指示本段的內(nèi)容范圍。假如響應(yīng)中包含 Content-Length,那么它的數(shù)值必須匹配它返回的內(nèi)容范圍的真實(shí)字節(jié)數(shù)。 Date ETag 和/或 Content-Location,假如同樣的請(qǐng)求本應(yīng)該返回200響應(yīng)。 Expires, Cache-Control,和/或 Vary,假如其值可能與之前相同變量的其他響應(yīng)對(duì)應(yīng)的值不同的話。 假如本響應(yīng)請(qǐng)求使用了 If-Range 強(qiáng)緩存驗(yàn)證,那么本次響應(yīng)不應(yīng)該包含其他實(shí)體頭;假如本響應(yīng)的請(qǐng)求使用了 If-Range 弱緩存驗(yàn)證,那么本次響應(yīng)禁止包含其他實(shí)體頭;這避免了緩存的實(shí)體內(nèi)容和更新了的實(shí)體頭信息之間的不一致。否則,本響應(yīng)就應(yīng)當(dāng)包含所有本應(yīng)該返回200響應(yīng)中應(yīng)當(dāng)返回的所有實(shí)體頭部域。 假如 ETag 或 Last-Modified 頭部不能精確匹配的話,則客戶端緩存應(yīng)禁止將206響應(yīng)返回的內(nèi)容與之前任何緩存過(guò)的內(nèi)容組合在一起。 任何不支持 Range 以及 Content-Range 頭的緩存都禁止緩存206響應(yīng)返回的內(nèi)容。207由WebDAV(RFC 2518)擴(kuò)展的狀態(tài)碼,代表之后的消息體將是一個(gè)XML消息,并且可能依照之前子請(qǐng)求數(shù)量的不同,包含一系列獨(dú)立的響應(yīng)代碼。300被請(qǐng)求的資源有一系列可供選擇的回饋信息,每個(gè)都有自己特定的地址和瀏覽器驅(qū)動(dòng)的商議信息。用戶或?yàn)g覽器能夠自行選擇一個(gè)首選的地址進(jìn)行重定向。 除非這是一個(gè) HEAD 請(qǐng)求,否則該響應(yīng)應(yīng)當(dāng)包括一個(gè)資源特性及地址的列表的實(shí)體,以便用戶或?yàn)g覽器從中選擇最合適的重定向地址。這個(gè)實(shí)體的格式由 Content-Type 定義的格式所決定。瀏覽器可能根據(jù)響應(yīng)的格式以及瀏覽器自身能力,自動(dòng)作出最合適的選擇。當(dāng)然,RFC 2616規(guī)范并沒(méi)有規(guī)定這樣的自動(dòng)選擇該如何進(jìn)行。 如果服務(wù)器本身已經(jīng)有了首選的回饋選擇,那么在 Location 中應(yīng)當(dāng)指明這個(gè)回饋的 URI;瀏覽器可能會(huì)將這個(gè) Location 值作為自動(dòng)重定向的地址。此外,除非額外指定,否則這個(gè)響應(yīng)也是可緩存的。301被請(qǐng)求的資源已永久移動(dòng)到新位置,并且將來(lái)任何對(duì)此資源的引用都應(yīng)該使用本響應(yīng)返回的若干個(gè) URI 之一。如果可能,擁有鏈接編輯功能的客戶端應(yīng)當(dāng)自動(dòng)把請(qǐng)求的地址修改為從服務(wù)器反饋回來(lái)的地址。除非額外指定,否則這個(gè)響應(yīng)也是可緩存的。 新的永久性的 URI 應(yīng)當(dāng)在響應(yīng)的 Location 域中返回。除非這是一個(gè) HEAD 請(qǐng)求,否則響應(yīng)的實(shí)體中應(yīng)當(dāng)包含指向新的 URI 的超鏈接及簡(jiǎn)短說(shuō)明。 如果這不是一個(gè) GET 或者 HEAD 請(qǐng)求,因此瀏覽器禁止自動(dòng)進(jìn)行重定向,除非得到用戶的確認(rèn),因?yàn)檎?qǐng)求的條件可能因此發(fā)生變化。 注意:對(duì)于某些使用 HTTP/1.0 協(xié)議的瀏覽器,當(dāng)它們發(fā)送的 POST 請(qǐng)求得到了一個(gè)301響應(yīng)的話,接下來(lái)的重定向請(qǐng)求將會(huì)變成 GET 方式。302請(qǐng)求的資源現(xiàn)在臨時(shí)從不同的 URI 響應(yīng)請(qǐng)求。由于這樣的重定向是臨時(shí)的,客戶端應(yīng)當(dāng)繼續(xù)向原有地址發(fā)送以后的請(qǐng)求。只有在Cache-Control或Expires中進(jìn)行了指定的情況下,這個(gè)響應(yīng)才是可緩存的。 新的臨時(shí)性的 URI 應(yīng)當(dāng)在響應(yīng)的 Location 域中返回。除非這是一個(gè) HEAD 請(qǐng)求,否則響應(yīng)的實(shí)體中應(yīng)當(dāng)包含指向新的 URI 的超鏈接及簡(jiǎn)短說(shuō)明。 如果這不是一個(gè) GET 或者 HEAD 請(qǐng)求,那么瀏覽器禁止自動(dòng)進(jìn)行重定向,除非得到用戶的確認(rèn),因?yàn)檎?qǐng)求的條件可能因此發(fā)生變化。 注意:雖然RFC 1945和RFC 2068規(guī)范不允許客戶端在重定向時(shí)改變請(qǐng)求的方法,但是很多現(xiàn)存的瀏覽器將302響應(yīng)視作為303響應(yīng),并且使用 GET 方式訪問(wèn)在 Location 中規(guī)定的 URI,而無(wú)視原先請(qǐng)求的方法。狀態(tài)碼303和307被添加了進(jìn)來(lái),用以明確服務(wù)器期待客戶端進(jìn)行何種反應(yīng)。303對(duì)應(yīng)當(dāng)前請(qǐng)求的響應(yīng)可以在另一個(gè) URI 上被找到,而且客戶端應(yīng)當(dāng)采用 GET 的方式訪問(wèn)那個(gè)資源。這個(gè)方法的存在主要是為了允許由腳本激活的POST請(qǐng)求輸出重定向到一個(gè)新的資源。這個(gè)新的 URI 不是原始資源的替代引用。同時(shí),303響應(yīng)禁止被緩存。當(dāng)然,第二個(gè)請(qǐng)求(重定向)可能被緩存。 新的 URI 應(yīng)當(dāng)在響應(yīng)的 Location 域中返回。除非這是一個(gè) HEAD 請(qǐng)求,否則響應(yīng)的實(shí)體中應(yīng)當(dāng)包含指向新的 URI 的超鏈接及簡(jiǎn)短說(shuō)明。 注意:許多 HTTP/1.1 版以前的 瀏覽器不能正確理解303狀態(tài)。如果需要考慮與這些瀏覽器之間的互動(dòng),302狀態(tài)碼應(yīng)該可以勝任,因?yàn)榇蠖鄶?shù)的瀏覽器處理302響應(yīng)時(shí)的方式恰恰就是上述規(guī)范要求客戶端處理303響應(yīng)時(shí)應(yīng)當(dāng)做的。304如果客戶端發(fā)送了一個(gè)帶條件的 GET 請(qǐng)求且該請(qǐng)求已被允許,而文檔的內(nèi)容(自上次訪問(wèn)以來(lái)或者根據(jù)請(qǐng)求的條件)并沒(méi)有改變,則服務(wù)器應(yīng)當(dāng)返回這個(gè)狀態(tài)碼。304響應(yīng)禁止包含消息體,因此始終以消息頭后的第一個(gè)空行結(jié)尾。 該響應(yīng)必須包含以下的頭信息: Date,除非這個(gè)服務(wù)器沒(méi)有時(shí)鐘。假如沒(méi)有時(shí)鐘的服務(wù)器也遵守這些規(guī)則,那么代理服務(wù)器以及客戶端可以自行將 Date 字段添加到接收到的響應(yīng)頭中去(正如RFC 2068中規(guī)定的一樣),緩存機(jī)制將會(huì)正常工作。 ETag 和/或 Content-Location,假如同樣的請(qǐng)求本應(yīng)返回200響應(yīng)。 Expires, Cache-Control,和/或Vary,假如其值可能與之前相同變量的其他響應(yīng)對(duì)應(yīng)的值不同的話。 假如本響應(yīng)請(qǐng)求使用了強(qiáng)緩存驗(yàn)證,那么本次響應(yīng)不應(yīng)該包含其他實(shí)體頭;否則(例如,某個(gè)帶條件的 GET 請(qǐng)求使用了弱緩存驗(yàn)證),本次響應(yīng)禁止包含其他實(shí)體頭;這避免了緩存了的實(shí)體內(nèi)容和更新了的實(shí)體頭信息之間的不一致。 假如某個(gè)304響應(yīng)指明了當(dāng)前某個(gè)實(shí)體沒(méi)有緩存,那么緩存系統(tǒng)必須忽視這個(gè)響應(yīng),并且重復(fù)發(fā)送不包含限制條件的請(qǐng)求。 假如接收到一個(gè)要求更新某個(gè)緩存條目的304響應(yīng),那么緩存系統(tǒng)必須更新整個(gè)條目以反映所有在響應(yīng)中被更新的字段的值。305被請(qǐng)求的資源必須通過(guò)指定的代理才能被訪問(wèn)。Location 域中將給出指定的代理所在的 URI 信息,接收者需要重復(fù)發(fā)送一個(gè)單獨(dú)的請(qǐng)求,通過(guò)這個(gè)代理才能訪問(wèn)相應(yīng)資源。只有原始服務(wù)器才能建立305響應(yīng)。 注意:RFC 2068中沒(méi)有明確305響應(yīng)是為了重定向一個(gè)單獨(dú)的請(qǐng)求,而且只能被原始服務(wù)器建立。忽視這些限制可能導(dǎo)致嚴(yán)重的安全后果。306在最新版的規(guī)范中,306狀態(tài)碼已經(jīng)不再被使用。307請(qǐng)求的資源現(xiàn)在臨時(shí)從不同的URI 響應(yīng)請(qǐng)求。由于這樣的重定向是臨時(shí)的,客戶端應(yīng)當(dāng)繼續(xù)向原有地址發(fā)送以后的請(qǐng)求。只有在Cache-Control或Expires中進(jìn)行了指定的情況下,這個(gè)響應(yīng)才是可緩存的。 新的臨時(shí)性的URI 應(yīng)當(dāng)在響應(yīng)的 Location 域中返回。除非這是一個(gè)HEAD 請(qǐng)求,否則響應(yīng)的實(shí)體中應(yīng)當(dāng)包含指向新的URI 的超鏈接及簡(jiǎn)短說(shuō)明。因?yàn)椴糠譃g覽器不能識(shí)別307響應(yīng),因此需要添加上述必要信息以便用戶能夠理解并向新的 URI 發(fā)出訪問(wèn)請(qǐng)求。 如果這不是一個(gè)GET 或者 HEAD 請(qǐng)求,那么瀏覽器禁止自動(dòng)進(jìn)行重定向,除非得到用戶的確認(rèn),因?yàn)檎?qǐng)求的條件可能因此發(fā)生變化。4001、語(yǔ)義有誤,當(dāng)前請(qǐng)求無(wú)法被服務(wù)器理解。除非進(jìn)行修改,否則客戶端不應(yīng)該重復(fù)提交這個(gè)請(qǐng)求。 2、請(qǐng)求參數(shù)有誤。401當(dāng)前請(qǐng)求需要用戶驗(yàn)證。該響應(yīng)必須包含一個(gè)適用于被請(qǐng)求資源的 WWW-Authenticate 信息頭用以詢問(wèn)用戶信息??蛻舳丝梢灾貜?fù)提交一個(gè)包含恰當(dāng)?shù)?Authorization 頭信息的請(qǐng)求。如果當(dāng)前請(qǐng)求已經(jīng)包含了 Authorization 證書,那么401響應(yīng)代表著服務(wù)器驗(yàn)證已經(jīng)拒絕了那些證書。如果401響應(yīng)包含了與前一個(gè)響應(yīng)相同的身份驗(yàn)證詢問(wèn),且瀏覽器已經(jīng)至少嘗試了一次驗(yàn)證,那么瀏覽器應(yīng)當(dāng)向用戶展示響應(yīng)中包含的實(shí)體信息,因?yàn)檫@個(gè)實(shí)體信息中可能包含了相關(guān)診斷信息。參見(jiàn)RFC 2617。402該狀態(tài)碼是為了將來(lái)可能的需求而預(yù)留的。403服務(wù)器已經(jīng)理解請(qǐng)求,但是拒絕執(zhí)行它。與401響應(yīng)不同的是,身份驗(yàn)證并不能提供任何幫助,而且這個(gè)請(qǐng)求也不應(yīng)該被重復(fù)提交。如果這不是一個(gè) HEAD 請(qǐng)求,而且服務(wù)器希望能夠講清楚為何請(qǐng)求不能被執(zhí)行,那么就應(yīng)該在實(shí)體內(nèi)描述拒絕的原因。當(dāng)然服務(wù)器也可以返回一個(gè)404響應(yīng),假如它不希望讓客戶端獲得任何信息。404請(qǐng)求失敗,請(qǐng)求所希望得到的資源未被在服務(wù)器上發(fā)現(xiàn)。沒(méi)有信息能夠告訴用戶這個(gè)狀況到底是暫時(shí)的還是永久的。假如服務(wù)器知道情況的話,應(yīng)當(dāng)使用410狀態(tài)碼來(lái)告知舊資源因?yàn)槟承﹥?nèi)部的配置機(jī)制問(wèn)題,已經(jīng)永久的不可用,而且沒(méi)有任何可以跳轉(zhuǎn)的地址。404這個(gè)狀態(tài)碼被廣泛應(yīng)用于當(dāng)服務(wù)器不想揭示到底為何請(qǐng)求被拒絕或者沒(méi)有其他適合的響應(yīng)可用的情況下。405請(qǐng)求行中指定的請(qǐng)求方法不能被用于請(qǐng)求相應(yīng)的資源。該響應(yīng)必須返回一個(gè)Allow 頭信息用以表示出當(dāng)前資源能夠接受的請(qǐng)求方法的列表。 鑒于 PUT,DELETE 方法會(huì)對(duì)服務(wù)器上的資源進(jìn)行寫操作,因而絕大部分的網(wǎng)頁(yè)服務(wù)器都不支持或者在默認(rèn)配置下不允許上述請(qǐng)求方法,對(duì)于此類請(qǐng)求均會(huì)返回405錯(cuò)誤。406請(qǐng)求的資源的內(nèi)容特性無(wú)法滿足請(qǐng)求頭中的條件,因而無(wú)法生成響應(yīng)實(shí)體。 除非這是一個(gè) HEAD 請(qǐng)求,否則該響應(yīng)就應(yīng)當(dāng)返回一個(gè)包含可以讓用戶或者瀏覽器從中選擇最合適的實(shí)體特性以及地址列表的實(shí)體。實(shí)體的格式由 Content-Type 頭中定義的媒體類型決定。瀏覽器可以根據(jù)格式及自身能力自行作出最佳選擇。但是,規(guī)范中并沒(méi)有定義任何作出此類自動(dòng)選擇的標(biāo)準(zhǔn)。407與401響應(yīng)類似,只不過(guò)客戶端必須在代理服務(wù)器上進(jìn)行身份驗(yàn)證。代理服務(wù)器必須返回一個(gè) Proxy-Authenticate 用以進(jìn)行身份詢問(wèn)??蛻舳丝梢苑祷匾粋€(gè) Proxy-Authorization 信息頭用以驗(yàn)證。參見(jiàn)RFC 2617。408請(qǐng)求超時(shí)。客戶端沒(méi)有在服務(wù)器預(yù)備等待的時(shí)間內(nèi)完成一個(gè)請(qǐng)求的發(fā)送??蛻舳丝梢噪S時(shí)再次提交這一請(qǐng)求而無(wú)需進(jìn)行任何更改。409由于和被請(qǐng)求的資源的當(dāng)前狀態(tài)之間存在沖突,請(qǐng)求無(wú)法完成。這個(gè)代碼只允許用在這樣的情況下才能被使用:用戶被認(rèn)為能夠解決沖突,并且會(huì)重新提交新的請(qǐng)求。該響應(yīng)應(yīng)當(dāng)包含足夠的信息以便用戶發(fā)現(xiàn)沖突的源頭。 沖突通常發(fā)生于對(duì) PUT 請(qǐng)求的處理中。例如,在采用版本檢查的環(huán)境下,某次 PUT 提交的對(duì)特定資源的修改請(qǐng)求所附帶的版本信息與之前的某個(gè)(第三方)請(qǐng)求向沖突,那么此時(shí)服務(wù)器就應(yīng)該返回一個(gè)409錯(cuò)誤,告知用戶請(qǐng)求無(wú)法完成。此時(shí),響應(yīng)實(shí)體中很可能會(huì)包含兩個(gè)沖突版本之間的差異比較,以便用戶重新提交歸并以后的新版本。410被請(qǐng)求的資源在服務(wù)器上已經(jīng)不再可用,而且沒(méi)有任何已知的轉(zhuǎn)發(fā)地址。這樣的狀況應(yīng)當(dāng)被認(rèn)為是永久性的。如果可能,擁有鏈接編輯功能的客戶端應(yīng)當(dāng)在獲得用戶許可后刪除所有指向這個(gè)地址的引用。如果服務(wù)器不知道或者無(wú)法確定這個(gè)狀況是否是永久的,那么就應(yīng)該使用404狀態(tài)碼。除非額外說(shuō)明,否則這個(gè)響應(yīng)是可緩存的。 410響應(yīng)的目的主要是幫助網(wǎng)站管理員維護(hù)網(wǎng)站,通知用戶該資源已經(jīng)不再可用,并且服務(wù)器擁有者希望所有指向這個(gè)資源的遠(yuǎn)端連接也被刪除。這類事件在限時(shí)、增值服務(wù)中很普遍。同樣,410響應(yīng)也被用于通知客戶端在當(dāng)前服務(wù)器站點(diǎn)上,原本屬于某個(gè)個(gè)人的資源已經(jīng)不再可用。當(dāng)然,是否需要把所有永久不可用的資源標(biāo)記為 410 Gone ,以及是否需要保持此標(biāo)記多長(zhǎng)時(shí)間,完全取決于服務(wù)器擁有者。411服務(wù)器拒絕在沒(méi)有定義 Content-Length 頭的情況下接受請(qǐng)求。在添加了表明請(qǐng)求消息體長(zhǎng)度的有效 Content-Length 頭之后,客戶端可以再次提交該請(qǐng)求。412服務(wù)器在驗(yàn)證在請(qǐng)求的頭字段中給出先決條件時(shí),沒(méi)能滿足其中的一個(gè)或多個(gè)。這個(gè)狀態(tài)碼允許客戶端在獲取資源時(shí)在請(qǐng)求的元信息(請(qǐng)求頭字段數(shù)據(jù))中設(shè)置先決條件,以此避免該請(qǐng)求方法被應(yīng)用到其希望的內(nèi)容以外的資源上。413服務(wù)器拒絕處理當(dāng)前請(qǐng)求,因?yàn)樵撜?qǐng)求提交的實(shí)體數(shù)據(jù)大小超過(guò)了服務(wù)器愿意或者能夠處理的范圍。此種情況下,服務(wù)器可以關(guān)閉連接以免客戶端繼續(xù)發(fā)送此請(qǐng)求。 如果這個(gè)狀況是臨時(shí)的,服務(wù)器應(yīng)當(dāng)返回一個(gè) Retry-After 的響應(yīng)頭,以告知客戶端可以在多少時(shí)間以后重新嘗試。414請(qǐng)求的URI 長(zhǎng)度超過(guò)了服務(wù)器能夠解釋的長(zhǎng)度,因此服務(wù)器拒絕對(duì)該請(qǐng)求提供服務(wù)。這比較少見(jiàn),通常的情況包括: 本應(yīng)使用POST方法的表單提交變成了GET方法,導(dǎo)致查詢字符串(Query String)過(guò)長(zhǎng)。 重定向URI “黑洞”,例如每次重定向把舊的 URI 作為新的 URI 的一部分,導(dǎo)致在若干次重定向后 URI 超長(zhǎng)。 客戶端正在嘗試?yán)媚承┓?wù)器中存在的安全漏洞攻擊服務(wù)器。這類服務(wù)器使用固定長(zhǎng)度的緩沖讀取或操作請(qǐng)求的 URI,當(dāng) GET 后的參數(shù)超過(guò)某個(gè)數(shù)值后,可能會(huì)產(chǎn)生緩沖區(qū)溢出,導(dǎo)致任意代碼被執(zhí)行[1]。沒(méi)有此類漏洞的服務(wù)器,應(yīng)當(dāng)返回414狀態(tài)碼。415對(duì)于當(dāng)前請(qǐng)求的方法和所請(qǐng)求的資源,請(qǐng)求中提交的實(shí)體并不是服務(wù)器中所支持的格式,因此請(qǐng)求被拒絕。416如果請(qǐng)求中包含了 Range 請(qǐng)求頭,并且 Range 中指定的任何數(shù)據(jù)范圍都與當(dāng)前資源的可用范圍不重合,同時(shí)請(qǐng)求中又沒(méi)有定義 If-Range 請(qǐng)求頭,那么服務(wù)器就應(yīng)當(dāng)返回416狀態(tài)碼。 假如 Range 使用的是字節(jié)范圍,那么這種情況就是指請(qǐng)求指定的所有數(shù)據(jù)范圍的首字節(jié)位置都超過(guò)了當(dāng)前資源的長(zhǎng)度。服務(wù)器也應(yīng)當(dāng)在返回416狀態(tài)碼的同時(shí),包含一個(gè) Content-Range 實(shí)體頭,用以指明當(dāng)前資源的長(zhǎng)度。這個(gè)響應(yīng)也被禁止使用 multipart/byteranges 作為其 Content-Type。417在請(qǐng)求頭 Expect 中指定的預(yù)期內(nèi)容無(wú)法被服務(wù)器滿足,或者這個(gè)服務(wù)器是一個(gè)代理服務(wù)器,它有明顯的證據(jù)證明在當(dāng)前路由的下一個(gè)節(jié)點(diǎn)上,Expect 的內(nèi)容無(wú)法被滿足。421從當(dāng)前客戶端所在的IP地址到服務(wù)器的連接數(shù)超過(guò)了服務(wù)器許可的最大范圍。通常,這里的IP地址指的是從服務(wù)器上看到的客戶端地址(比如用戶的網(wǎng)關(guān)或者代理服務(wù)器地址)。在這種情況下,連接數(shù)的計(jì)算可能涉及到不止一個(gè)終端用戶。422從當(dāng)前客戶端所在的IP地址到服務(wù)器的連接數(shù)超過(guò)了服務(wù)器許可的最大范圍。通常,這里的IP地址指的是從服務(wù)器上看到的客戶端地址(比如用戶的網(wǎng)關(guān)或者代理服務(wù)器地址)。在這種情況下,連接數(shù)的計(jì)算可能涉及到不止一個(gè)終端用戶。422請(qǐng)求格式正確,但是由于含有語(yǔ)義錯(cuò)誤,無(wú)法響應(yīng)。(RFC 4918 WebDAV)423 Locked 當(dāng)前資源被鎖定。(RFC 4918 WebDAV)424由于之前的某個(gè)請(qǐng)求發(fā)生的錯(cuò)誤,導(dǎo)致當(dāng)前請(qǐng)求失敗,例如 PROPPATCH。(RFC 4918 WebDAV)425在WebDav Advanced Collections 草案中定義,但是未出現(xiàn)在《WebDAV 順序集協(xié)議》(RFC 3658)中。426客戶端應(yīng)當(dāng)切換到TLS/1.0。(RFC 2817)449由微軟擴(kuò)展,代表請(qǐng)求應(yīng)當(dāng)在執(zhí)行完適當(dāng)?shù)牟僮骱筮M(jìn)行重試。500服務(wù)器遇到了一個(gè)未曾預(yù)料的狀況,導(dǎo)致了它無(wú)法完成對(duì)請(qǐng)求的處理。一般來(lái)說(shuō),這個(gè)問(wèn)題都會(huì)在服務(wù)器的程序碼出錯(cuò)時(shí)出現(xiàn)。501服務(wù)器不支持當(dāng)前請(qǐng)求所需要的某個(gè)功能。當(dāng)服務(wù)器無(wú)法識(shí)別請(qǐng)求的方法,并且無(wú)法支持其對(duì)任何資源的請(qǐng)求。502作為網(wǎng)關(guān)或者代理工作的服務(wù)器嘗試執(zhí)行請(qǐng)求時(shí),從上游服務(wù)器接收到無(wú)效的響應(yīng)。503由于臨時(shí)的服務(wù)器維護(hù)或者過(guò)載,服務(wù)器當(dāng)前無(wú)法處理請(qǐng)求。這個(gè)狀況是臨時(shí)的,并且將在一段時(shí)間以后恢復(fù)。如果能夠預(yù)計(jì)延遲時(shí)間,那么響應(yīng)中可以包含一個(gè) Retry-After 頭用以標(biāo)明這個(gè)延遲時(shí)間。如果沒(méi)有給出這個(gè) Retry-After 信息,那么客戶端應(yīng)當(dāng)以處理500響應(yīng)的方式處理它。 注意:503狀態(tài)碼的存在并不意味著服務(wù)器在過(guò)載的時(shí)候必須使用它。某些服務(wù)器只不過(guò)是希望拒絕客戶端的連接。504作為網(wǎng)關(guān)或者代理工作的服務(wù)器嘗試執(zhí)行請(qǐng)求時(shí),未能及時(shí)從上游服務(wù)器(URI標(biāo)識(shí)出的服務(wù)器,例如HTTP、FTP、LDAP)或者輔助服務(wù)器(例如DNS)收到響應(yīng)。 注意:某些代理服務(wù)器在DNS查詢超時(shí)時(shí)會(huì)返回400或者500錯(cuò)誤505服務(wù)器不支持,或者拒絕支持在請(qǐng)求中使用的 HTTP 版本。這暗示著服務(wù)器不能或不愿使用與客戶端相同的版本。響應(yīng)中應(yīng)當(dāng)包含一個(gè)描述了為何版本不被支持以及服務(wù)器支持哪些協(xié)議的實(shí)體。506由《透明內(nèi)容協(xié)商協(xié)議》(RFC 2295)擴(kuò)展,代表服務(wù)器存在內(nèi)部配置錯(cuò)誤:被請(qǐng)求的協(xié)商變?cè)Y源被配置為在透明內(nèi)容協(xié)商中使用自己,因此在一個(gè)協(xié)商處理中不是一個(gè)合適的重點(diǎn)。507服務(wù)器無(wú)法存儲(chǔ)完成請(qǐng)求所必須的內(nèi)容。這個(gè)狀況被認(rèn)為是臨時(shí)的。WebDAV (RFC 4918)509服務(wù)器達(dá)到帶寬限制。這不是一個(gè)官方的狀態(tài)碼,但是仍被廣泛使用。510獲取資源所需要的策略并沒(méi)有沒(méi)滿足。(RFC 2774)

最后,大部分資料均由網(wǎng)上整理所得,感謝所有奉獻(xiàn)的前輩同仁!

【推薦課程:http視頻教程】

以上就是前端開(kāi)發(fā)者必須知道的http協(xié)議相關(guān)知識(shí)的詳細(xì)內(nèi)容,html教程

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
欧美大片拔萝卜| 香蕉国产精品偷在线观看不卡| 免费成人在线视频网站| 欧洲激情视频| 国产成人精品亚洲午夜麻豆| 国产成都精品91一区二区三| 欧美最猛性xxxxxhd| 国产成人精品久久亚洲高清不卡| 亚洲一区日韩精品| 999在线观看免费大全电视剧| 波多野结衣视频免费观看| 亚洲色欲色欲www| 国产精品一区二区小说| 中文字幕第28页| 日韩国产欧美精品一区二区三区| 99国产精品私拍| 一区二区三区在线免费观看| 2020国内自拍视频| 青青在线视频观看| 国产精品xxxav免费视频| 免费在线观看一级片| 国产绳艺sm调教室论坛| 亚洲裸体视频| 欧美另类综合| 一级黄色a毛片| 成年视频在线观看| 国产黄色小视频| 成人免费小视频| 污视频在线观看免费网站| 1000精品久久久久久久久| 欧美日韩免费不卡视频一区二区三区| 欧美性bbb| 538精品在线视频| 羞羞网站在线观看入口免费| 国产99久久精品一区二区 夜夜躁日日躁| 国产成人aaaa| 97视频免费| 一区二区三区四区免费视频| 激情综合亚洲| 欧美 日韩 国产 成人 在线 91| 欧美久久久久久久久久久久| 亚洲欧美日产图| 26uuu色噜噜精品一区二区| 日韩电影在线观看永久视频免费网站| xxxx日本免费| 日韩中文综合网| 午夜精品视频在线观看一区二区| 日韩av免费一区| 国产精品综合久久久久| 免费成人看片网址| hd国产人妖ts另类视频| 色欲AV无码精品一区二区久久| 亚洲一卡2卡三卡4卡2021四卡| 久热国产精品视频一区二区三区| 情事1991在线| 欧美极度另类videos高清| 欧美日韩精品国产| 99精品国产99久久久久久97| 国产激情一区二区三区四区| 麻豆成人小视频| 国产精品国产馆在线真实露脸| 日韩精品一二区| h版电影在线播放视频网站| 亚洲色偷精品一区二区三区| 91香蕉视频在线观看| 亚洲中文字幕在线一区| 最新天堂在线视频| 欧美一区二区三区小说| 国产夫绿帽单男3p精品视频| 国产哺乳奶水91在线播放| a屁视频一区二区三区四区| 久久久久久久久免费| 亚洲av成人片无码| 欧美高清视频在线观看mv| 久草国产在线观看| 国产欧美最新羞羞视频在线观看| 国产1区2区视频| 欧美视频导航| 欧美黑人xxxxx性受| 亚洲少妇中文在线| 麻豆久久久久久久久久| 午夜视频福利在线观看| 亚洲国产精品va在线看黑人动漫| 欧美激情亚洲视频| 日日骚一区二区三区| 国产精品免费一区二区三区都可以| 欧美乱妇23p| 日韩毛片中文字幕| 999国产精品一区| 92看片淫黄大片看国产片| 欧美精品在线网站| 国产韩日影视精品| 成人羞羞动漫| 日本一区二区高清不卡| 97se亚洲国产综合自在线观| 国产精品自在欧美一区| 在线观看中文字幕的网站| 日韩av一卡二卡| www.超碰在线.com| 国产精品久久久久天堂| 欧美影院三区| 综合国产精品久久久| 欧美撒尿777hd撒尿| 色综合久久88色综合天天提莫| 路边理发店露脸熟妇泻火| 中文字幕人成高视频| 屁屁影院在线观看| 日韩中文在线视频| 成人做爰视频网站| 中文字幕在线一二| 中文字幕视频网站| 91精品国产自产观看在线| 嫩草在线播放| 成人18视频免费69| 国产乱码精品一区二区三区中文| 男女免费视频网站| 性欧美.com| 日本韩国欧美三级| 超碰成人在线观看| 亚洲综合久久久| 日本综合字幕| 国产精品探花视频| 国产美女在线一区二区三区| 国产欧美一区二区三区在线老狼| 日本www高清视频| 黄网站免费看| 亚洲mm色国产网站| 瑟瑟视频在线看| 国产欧美一二三区| 日韩精品久久一区| 884aa四虎影成人精品一区| 超污视频在线播放| 在线观看国产原创自拍视频| 日本a级片视频| 欧美极品视频在线观看| 成人精品视频久久久久| 成人综合在线视频| 欧美乱妇高清无乱码免费| 91av在线视频观看| 欧美精品v日韩精品v国产精品| 日本一区二区三区视频在线| 中文字幕观看av| 国产人成亚洲第一网站在线播放| 综合国产第二页| 亚洲激情午夜| 国产裸体美女永久免费无遮挡| 久久99九九| 中文字幕一区二区视频| 2020日本不卡一区二区视频| 国产欧美日韩精品在线观看| 草莓视频app18在线视频| 成人嘿咻视频免费看| av在线你懂的| 免费av一区二区| 欧美成人精品在线观看| 欧美无人区码suv| 黄瓜视频成人app免费| 午夜精品久久久久久久蜜桃app| 高清一区二区三区四区五区| 国产在线视频三区| 美女一区二区三区在线观看| 久久视频国产精品免费视频在线| 久久综合九色欧美综合狠狠| 日韩主播视频在线| 欧美一区二区三区久久| 日本三级黄色网址| 国产aaaaaaaaa| 欧美综合在线视频观看| 思99热精品久久只有精品| 国产精品久久久久久久7电影| 自由的xxxx在线视频| 99国内精品久久久久久久软件| 日韩护士脚交太爽了| 欧美亚洲国产日本| 亚洲a一区二区| 国产一区二区三区在线免费| 青青草观看免费视频在线| www.日本精品| 国产精品69久久久| 日本不卡一二三区黄网| 欧美精品三级在线| 亚洲欧美日本一区二区| 日本久久高清视频| 三妻四妾的电影电视剧在线观看| 国产在线不卡精品| 欧美在线国产| 日本午夜在线亚洲.国产| 毛片毛片毛片毛| 国产美女主播视频一区| 国产成人免费av一区二区午夜| 二区三区中文字幕| 精品成人一区二区三区免费视频| 国产97色在线 | 日韩| 91精品国产91久久久久久吃药| 一级精品视频在线观看宜春院| av电影天堂一区二区在线| 国产一区亚洲二区三区| 日韩妆和欧美的一区二区| 中文字幕理伦片免费看| 精品久久久久久久久久久久久久久久| 992tv成人免费视频| 99精品欧美一区二区三区小说| 亚洲精品国产拍免费91在线| 很黄很黄的网站免费的| 亚洲欧美www| 欧美极品日韩| 精品深夜av无码一区二区老年| 中文在线观看视频| 国产成在线观看免费视频| 粉嫩av一区二区三区四区五区| 七七婷婷婷婷精品国产| 日韩人妻无码精品综合区| 七七婷婷婷婷精品国产| 亚洲视频一区| 夜夜嗨aⅴ一区二区三区| 精品国产一区二区三区日日嗨| 强制高潮抽搐sm调教高h| 日韩精品麻豆| 国产suv精品一区二区883| 9999久久久久| 精品人妻互换一区二区三区| 午夜精品aaa| 亚洲视频 欧洲视频| 久久成年人视频| 免费看黄色的网站| 四虎精品一区二区永久在线观看| 午夜伦理在线视频| 成年人午夜免费视频| 成年网址网站在线观看| 国产精品www网站| 福利欧美精品在线| 欧美日韩中文字幕综合视频| 91成人精品网站| 经典三级在线视频| 最好看的日本字幕mv视频大全| 成人在线观看网址| 黄色无遮挡网站| 久久国产综合| 色婷婷久久综合| 色94色欧美sute亚洲线路一ni| 成人涩涩网站| 在线观看毛片网站| 狼人综合视频| free性丰满69性欧美| 国产午夜精品一区二区三区四区| 3atv一区二区三区| bt7086福利一区国产| 后入内射无码人妻一区| 国产三区在线视频| 91国产高清在线| 伊人久久大香线蕉无限次| 女同互添互慰av毛片观看| 92看片淫黄大片看国产片| 亚洲另类黄色| 亚洲大片免费观看| 久久精品国产99精品国产亚洲性色| 欧美一级片在线免费观看| 欧美一区二区视频在线观看2020| 亚洲天堂a在线| 91首页免费视频| 91片在线免费观看| avove在线播放| 日韩av女优在线观看| 国偷自产av一区二区三区麻豆| 人妻少妇精品一区二区三区| 在线日韩中文| 国产私拍精品| 38少妇精品导航| 日韩中文字幕在线视频| 最新中文字幕日本| 亚洲免费看av| 欧美视频亚洲色图| av不卡在线播放| 免费国产自线拍一欧美视频| 六月丁香在线视频| 夜夜嗨av一区二区三区中文字幕| 亚洲电影中文字幕在线观看| 久草福利资源在线观看| 亚洲精品鲁一鲁一区二区三区| 日韩av综合在线| 欧美国产精品va在线观看| av在线app| 狠狠v欧美v日韩v亚洲ⅴ| 国产欧美成人| 亚洲激情五月| 北条麻妃在线视频观看| 欧美mv日韩| 国模私拍一区二区| 久久久久成人精品无码| 国产裸体视频网站| seseavlu视频在线| av大片在线播放| 欧美激情中文字幕在线| 久久中国妇女中文字幕| 黄色一级a毛片| 亚洲一区国产视频| 国产7777| 国产成人久久精品77777| 日韩一区二区三区视频在线观看| www.欧美亚洲| 超碰在线公开| а√天堂中文资源在线bt| 福利小视频在线观看| 亚洲国产精品人人爽夜夜爽| 国产精品天天操| 国产精品久久久久9999赢消| 久久露脸国产精品| 牛牛精品在线视频| 波多野结衣先锋影音| 欧美精品一区二区久久婷婷| 56国语精品自产拍在线观看| 久久久久久国产精品视频| 亚洲mv在线| 中文字幕国产综合| 亚洲国产成人久久综合一区| 国产精品入口麻豆免费| 手机亚洲手机国产手机日韩| 日本wwww视频| 日韩亚洲成人av在线| 久久精品亚洲7777影院| gv天堂gv无码男同在线观看| 欧美日韩亚洲一区在线观看| 久久激情一区| 在线观看av黄网站永久| 成人软件网18免费视频| 男女全黄做爰文章| 国产在线视视频有精品| 免费在线精品视频|