麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

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

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

2020-03-24 16:30:27
字體:
供稿:網(wǎng)友

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

1.概念

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

2.發(fā)展

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

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

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

1.0版本支持非持久連接,也就是說經(jīng)過tcp協(xié)議(http是基于TCP的應(yīng)用層協(xié)議)三次握手建立連接后,服務(wù)端只能發(fā)送一個(gè)對(duì)象給瀏覽器,然后鏈接即斷開,如果網(wǎng)頁中包含其他內(nèi)聯(lián)對(duì)象,如圖片,html' target='_blank'>js文件,css文件等,則需要建立多次鏈接,這其中就會(huì)導(dǎo)致多次建立/斷開連接的開銷。而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è)域感覺可有可無,也許是為了提高速度吧。畢竟直接指定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í)體,從而在某些無法響應(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通信過程

(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瀏覽器可接受的語言Accept-Language: en,zhAccept-Ranges可以請(qǐng)求網(wǎng)頁實(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)容長度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: [email protected]指定請(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限制信息通過代理和網(wǎng)關(guān)傳送的時(shí)間Max-Forwards: 10Pragma用來包含實(shí)現(xiàn)特定的指令Pragma: no-cacheProxy-Authorization連接到代理的授權(quán)證書Proxy-Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==Range只請(qǐng)求實(shí)體的一部分,指定范圍Range: bytes=500-999Referer先前網(wǎng)頁的地址,當(dāng)前請(qǐng)求網(wǎng)頁緊隨其后,即來路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)體的語言Content-Language: en,zhContent-Length響應(yī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)過期的日期和時(shí)間Expires: Thu, 01 Dec 2010 16:00:00 GMTLast-Modified請(qǐng)求資源的最后修改時(shí)間Last-Modified: Tue, 15 Nov 2010 12:45:26 GMTLocation用來重定向接收方到非請(qǐng)求URL的位置來完成請(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)是通過哪里發(fā)送的Via: 1.0 fred, 1.1 nowhere.com (Apache/1.1)Warning警告實(shí)體可能存在的問題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)求信息,主要用于測試或診斷
CONNECT 保留將來使用
OPTIONS 請(qǐng)求查詢服務(wù)器的性能,或者查詢與資源相關(guān)的選項(xiàng)和需求

6. 狀態(tài)碼

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

狀態(tà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)求有語法錯(cuò)誤或請(qǐng)求無法實(shí)現(xiàn)

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

狀態(tài)嗎碼大全

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

狀態(tài)碼狀態(tài)碼英文名稱中文描述1開頭的狀態(tài)碼100Continue繼續(xù)。客戶端應(yīng)繼續(xù)其請(qǐng)求101Switching Protocols切換協(xié)議。服務(wù)器根據(jù)客戶端的請(qǐng)求切換協(xié)議。只能切換到更高級(jí)的協(xié)議,例如,切換到HTTP的新版本協(xié)議2開頭的狀態(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無內(nèi)容。服務(wù)器成功處理,但未返回內(nèi)容。在未更新網(wǎng)頁的情況下,可確保瀏覽器繼續(xù)顯示當(dāng)前文檔205Reset Content重置內(nèi)容。服務(wù)器處理成功,用戶終端(例如:瀏覽器)應(yīng)重置文檔視圖。可通過此返回碼清除瀏覽器的表單域206Partial Content部分內(nèi)容。服務(wù)器成功處理了部分GET請(qǐng)求3開頭的狀態(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ì)緩存訪問過的資源,通過提供一個(gè)頭信息指出客戶端希望只返回在指定日期之后修改的資源305Use Proxy使用代理。所請(qǐng)求的資源必須通過代理訪問306Unused已經(jīng)被廢棄的HTTP狀態(tài)碼307Temporary Redirect臨時(shí)重定向。與302類似。使用GET請(qǐng)求重定向4開頭的狀態(tài)碼400Bad Request客戶端請(qǐng)求的語法錯(cuò)誤,服務(wù)器無法理解401Unauthorized請(qǐng)求要求用戶的身份認(rèn)證402Payment Required保留,將來使用403Forbidden服務(wù)器理解請(qǐng)求客戶端的請(qǐng)求,但是拒絕執(zhí)行此請(qǐng)求404Not Found服務(wù)器無法根據(jù)客戶端的請(qǐng)求找到資源(網(wǎng)頁)。通過此代碼,網(wǎng)站設(shè)計(jì)人員可設(shè)置 您所請(qǐng)求的資源無法找到 的個(gè)性頁面405Method Not Allowed客戶端請(qǐng)求中的方法被禁止406Not Acceptable服務(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í)間過長,超時(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ì)人員可通過301代碼指定資源的新位置411Length Required服務(wù)器無法處理客戶端發(fā)送的不帶Content-Length的請(qǐng)求信息412Precondition Failed客戶端請(qǐng)求信息的先決條件錯(cuò)誤413Request Entity Too Large由于請(qǐng)求的實(shí)體過大,服務(wù)器無法處理,因此拒絕請(qǐng)求。為防止客戶端的連續(xù)請(qǐng)求,服務(wù)器可能會(huì)關(guān)閉連接。如果只是服務(wù)器暫時(shí)無法處理,則會(huì)包含一個(gè)Retry-After的響應(yīng)信息414Request-URI Too Large請(qǐng)求的URI過長(URI通常為網(wǎng)址),服務(wù)器無法處理415Unsupported Media Type服務(wù)器無法處理請(qǐng)求附帶的媒體格式416Requested range not satisfiable客戶端請(qǐng)求的范圍無效417Expectation Failed服務(wù)器無法滿足Expect的請(qǐng)求頭信息5開頭的狀態(tài)碼500Internal Server Error服務(wù)器內(nèi)部錯(cuò)誤,無法完成請(qǐng)求501Not Implemented服務(wù)器不支持請(qǐng)求的功能,無法完成請(qǐng)求502Bad Gateway充當(dāng)網(wǎng)關(guān)或代理的服務(wù)器,從遠(yuǎn)端服務(wù)器接收到了一個(gè)無效的請(qǐng)求503Service Unavailable由于超載或系統(tǒng)維護(hù),服務(wù)器暫時(shí)的無法處理客戶端的請(qǐng)求。延時(shí)的長度可包含在服務(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é)議的版本,無法完成處理

表2 詳細(xì)介紹表

狀態(tài)碼含義100客戶端應(yīng)當(dāng)繼續(xù)發(fā)送請(qǐng)求。這個(gè)臨時(shí)響應(yīng)是用來通知客戶端它的部分請(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)求,并將通過Upgrade 消息頭通知客戶端采用不同的協(xié)議來完成這個(gè)請(qǐng)求。在發(fā)送完這個(gè)響應(yīng)最后的空行后,服務(wù)器將會(huì)切換到在Upgrade 消息頭中定義的那些協(xié)議。 只有在切換新的協(xié)議更有好處的時(shí)候才應(yīng)該采取類似措施。例如,切換到新的HTTP 版本比舊版本更有優(yōu)勢,或者切換到一個(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 頭信息返回。假如需要的資源無法及時(shí)建立的話,應(yīng)當(dāng)返回 202 Accepted 。202服務(wù)器已接受請(qǐng)求,但尚未處理。正如它可能被拒絕一樣,最終該請(qǐng)求可能會(huì)也可能不會(huì)被執(zhí)行。在異步操作的場合下,沒有比發(fā)送這個(gè)狀態(tài)碼更方便的做法了。 返回202狀態(tài)碼的響應(yīng)的目的是允許服務(wù)器接受其他過程的請(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ù)測的指針,以便用戶能夠估計(jì)操作是否已經(jīng)完成。203服務(wù)器已成功處理了請(qǐng)求,但返回的實(shí)體頭部元信息不是在原始服務(wù)器上有效的確定集合,而是來自本地或者第三方的拷貝。當(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)可能通過實(shí)體頭部的形式,返回新的或更新后的元信息。如果存在這些頭部信息,則應(yīng)當(dāng)與所請(qǐng)求的變量相呼應(yīng)。 如果客戶端是瀏覽器的話,那么用戶瀏覽器應(yīng)保留發(fā)送了該請(qǐng)求的頁面,而不產(chǎn)生任何文檔視圖上的變化,即使按照規(guī)范新的或更新后的元信息應(yīng)當(dāng)被應(yīng)用到用戶瀏覽器活動(dòng)視圖中的文檔。 由于204響應(yīng)被禁止包含任何消息體,因此它始終以消息頭后的第一個(gè)空行結(jié)尾。205服務(wù)器成功處理了請(qǐng)求,且沒有返回任何內(nèi)容。但是與204響應(yīng)不同,返回此狀態(tài)碼的響應(yīng)要求請(qǐng)求者重置文檔視圖。該響應(yīng)主要是被用于接受用戶輸入后,立即重置表單,以便用戶能夠輕松地開始另一次輸入。 與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 頭信息來指示客戶端希望得到的內(nèi)容范圍,并且可能包含 If-Range 來作為請(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)容與之前任何緩存過的內(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ī)范并沒有規(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)到新位置,并且將來任何對(duì)此資源的引用都應(yīng)該使用本響應(yīng)返回的若干個(gè) URI 之一。如果可能,擁有鏈接編輯功能的客戶端應(yīng)當(dāng)自動(dòng)把請(qǐng)求的地址修改為從服務(wù)器反饋回來的地址。除非額外指定,否則這個(gè)響應(yīng)也是可緩存的。 新的永久性的 URI 應(yīng)當(dāng)在響應(yīng)的 Location 域中返回。除非這是一個(gè) HEAD 請(qǐng)求,否則響應(yīng)的實(shí)體中應(yīng)當(dāng)包含指向新的 URI 的超鏈接及簡短說明。 如果這不是一個(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)的話,接下來的重定向請(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 的超鏈接及簡短說明。 如果這不是一個(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 方式訪問在 Location 中規(guī)定的 URI,而無視原先請(qǐng)求的方法。狀態(tài)碼303和307被添加了進(jìn)來,用以明確服務(wù)器期待客戶端進(jìn)行何種反應(yīng)。303對(duì)應(yīng)當(dāng)前請(qǐng)求的響應(yīng)可以在另一個(gè) URI 上被找到,而且客戶端應(yīng)當(dāng)采用 GET 的方式訪問那個(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 的超鏈接及簡短說明。 注意:許多 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)容(自上次訪問以來或者根據(jù)請(qǐng)求的條件)并沒有改變,則服務(wù)器應(yīng)當(dāng)返回這個(gè)狀態(tài)碼。304響應(yīng)禁止包含消息體,因此始終以消息頭后的第一個(gè)空行結(jié)尾。 該響應(yīng)必須包含以下的頭信息: Date,除非這個(gè)服務(wù)器沒有時(shí)鐘。假如沒有時(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í)體沒有緩存,那么緩存系統(tǒng)必須忽視這個(gè)響應(yīng),并且重復(fù)發(fā)送不包含限制條件的請(qǐng)求。 假如接收到一個(gè)要求更新某個(gè)緩存條目的304響應(yīng),那么緩存系統(tǒng)必須更新整個(gè)條目以反映所有在響應(yīng)中被更新的字段的值。305被請(qǐng)求的資源必須通過指定的代理才能被訪問。Location 域中將給出指定的代理所在的 URI 信息,接收者需要重復(fù)發(fā)送一個(gè)單獨(dú)的請(qǐng)求,通過這個(gè)代理才能訪問相應(yīng)資源。只有原始服務(wù)器才能建立305響應(yīng)。 注意:RFC 2068中沒有明確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 的超鏈接及簡短說明。因?yàn)椴糠譃g覽器不能識(shí)別307響應(yīng),因此需要添加上述必要信息以便用戶能夠理解并向新的 URI 發(fā)出訪問請(qǐng)求。 如果這不是一個(gè)GET 或者 HEAD 請(qǐng)求,那么瀏覽器禁止自動(dòng)進(jìn)行重定向,除非得到用戶的確認(rèn),因?yàn)檎?qǐng)求的條件可能因此發(fā)生變化。4001、語義有誤,當(dāng)前請(qǐng)求無法被服務(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 信息頭用以詢問用戶信息。客戶端可以重復(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)證詢問,且瀏覽器已經(jīng)至少嘗試了一次驗(yàn)證,那么瀏覽器應(yīng)當(dāng)向用戶展示響應(yīng)中包含的實(shí)體信息,因?yàn)檫@個(gè)實(shí)體信息中可能包含了相關(guān)診斷信息。參見RFC 2617。402該狀態(tà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)。沒有信息能夠告訴用戶這個(gè)狀況到底是暫時(shí)的還是永久的。假如服務(wù)器知道情況的話,應(yīng)當(dāng)使用410狀態(tài)碼來告知舊資源因?yàn)槟承﹥?nèi)部的配置機(jī)制問題,已經(jīng)永久的不可用,而且沒有任何可以跳轉(zhuǎn)的地址。404這個(gè)狀態(tài)碼被廣泛應(yīng)用于當(dāng)服務(wù)器不想揭示到底為何請(qǐng)求被拒絕或者沒有其他適合的響應(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)頁服務(wù)器都不支持或者在默認(rèn)配置下不允許上述請(qǐng)求方法,對(duì)于此類請(qǐng)求均會(huì)返回405錯(cuò)誤。406請(qǐng)求的資源的內(nèi)容特性無法滿足請(qǐng)求頭中的條件,因而無法生成響應(yīng)實(shí)體。 除非這是一個(gè) HEAD 請(qǐng)求,否則該響應(yīng)就應(yīng)當(dāng)返回一個(gè)包含可以讓用戶或者瀏覽器從中選擇最合適的實(shí)體特性以及地址列表的實(shí)體。實(shí)體的格式由 Content-Type 頭中定義的媒體類型決定。瀏覽器可以根據(jù)格式及自身能力自行作出最佳選擇。但是,規(guī)范中并沒有定義任何作出此類自動(dòng)選擇的標(biāo)準(zhǔn)。407與401響應(yīng)類似,只不過客戶端必須在代理服務(wù)器上進(jìn)行身份驗(yàn)證。代理服務(wù)器必須返回一個(gè) Proxy-Authenticate 用以進(jìn)行身份詢問。客戶端可以返回一個(gè) Proxy-Authorization 信息頭用以驗(yàn)證。參見RFC 2617。408請(qǐng)求超時(shí)。客戶端沒有在服務(wù)器預(yù)備等待的時(shí)間內(nèi)完成一個(gè)請(qǐng)求的發(fā)送。客戶端可以隨時(shí)再次提交這一請(qǐng)求而無需進(jìn)行任何更改。409由于和被請(qǐng)求的資源的當(dāng)前狀態(tài)之間存在沖突,請(qǐng)求無法完成。這個(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)求無法完成。此時(shí),響應(yīng)實(shí)體中很可能會(huì)包含兩個(gè)沖突版本之間的差異比較,以便用戶重新提交歸并以后的新版本。410被請(qǐng)求的資源在服務(wù)器上已經(jīng)不再可用,而且沒有任何已知的轉(zhuǎn)發(fā)地址。這樣的狀況應(yīng)當(dāng)被認(rèn)為是永久性的。如果可能,擁有鏈接編輯功能的客戶端應(yīng)當(dāng)在獲得用戶許可后刪除所有指向這個(gè)地址的引用。如果服務(wù)器不知道或者無法確定這個(gè)狀況是否是永久的,那么就應(yīng)該使用404狀態(tài)碼。除非額外說明,否則這個(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)記多長時(shí)間,完全取決于服務(wù)器擁有者。411服務(wù)器拒絕在沒有定義 Content-Length 頭的情況下接受請(qǐng)求。在添加了表明請(qǐng)求消息體長度的有效 Content-Length 頭之后,客戶端可以再次提交該請(qǐng)求。412服務(wù)器在驗(yàn)證在請(qǐng)求的頭字段中給出先決條件時(shí),沒能滿足其中的一個(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ù)大小超過了服務(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 長度超過了服務(wù)器能夠解釋的長度,因此服務(wù)器拒絕對(duì)該請(qǐng)求提供服務(wù)。這比較少見,通常的情況包括: 本應(yīng)使用POST方法的表單提交變成了GET方法,導(dǎo)致查詢字符串(Query String)過長。 重定向URI “黑洞”,例如每次重定向把舊的 URI 作為新的 URI 的一部分,導(dǎo)致在若干次重定向后 URI 超長。 客戶端正在嘗試?yán)媚承┓?wù)器中存在的安全漏洞攻擊服務(wù)器。這類服務(wù)器使用固定長度的緩沖讀取或操作請(qǐng)求的 URI,當(dāng) GET 后的參數(shù)超過某個(gè)數(shù)值后,可能會(huì)產(chǎn)生緩沖區(qū)溢出,導(dǎo)致任意代碼被執(zhí)行[1]。沒有此類漏洞的服務(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)求中又沒有定義 If-Range 請(qǐng)求頭,那么服務(wù)器就應(yīng)當(dāng)返回416狀態(tài)碼。 假如 Range 使用的是字節(jié)范圍,那么這種情況就是指請(qǐng)求指定的所有數(shù)據(jù)范圍的首字節(jié)位置都超過了當(dāng)前資源的長度。服務(wù)器也應(yīng)當(dāng)在返回416狀態(tài)碼的同時(shí),包含一個(gè) Content-Range 實(shí)體頭,用以指明當(dāng)前資源的長度。這個(gè)響應(yīng)也被禁止使用 multipart/byteranges 作為其 Content-Type。417在請(qǐng)求頭 Expect 中指定的預(yù)期內(nèi)容無法被服務(wù)器滿足,或者這個(gè)服務(wù)器是一個(gè)代理服務(wù)器,它有明顯的證據(jù)證明在當(dāng)前路由的下一個(gè)節(jié)點(diǎn)上,Expect 的內(nèi)容無法被滿足。421從當(dāng)前客戶端所在的IP地址到服務(wù)器的連接數(shù)超過了服務(wù)器許可的最大范圍。通常,這里的IP地址指的是從服務(wù)器上看到的客戶端地址(比如用戶的網(wǎng)關(guān)或者代理服務(wù)器地址)。在這種情況下,連接數(shù)的計(jì)算可能涉及到不止一個(gè)終端用戶。422從當(dāng)前客戶端所在的IP地址到服務(wù)器的連接數(shù)超過了服務(wù)器許可的最大范圍。通常,這里的IP地址指的是從服務(wù)器上看到的客戶端地址(比如用戶的網(wǎng)關(guān)或者代理服務(wù)器地址)。在這種情況下,連接數(shù)的計(jì)算可能涉及到不止一個(gè)終端用戶。422請(qǐng)求格式正確,但是由于含有語義錯(cuò)誤,無法響應(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)致了它無法完成對(duì)請(qǐng)求的處理。一般來說,這個(gè)問題都會(huì)在服務(wù)器的程序碼出錯(cuò)時(shí)出現(xiàn)。501服務(wù)器不支持當(dāng)前請(qǐng)求所需要的某個(gè)功能。當(dāng)服務(wù)器無法識(shí)別請(qǐng)求的方法,并且無法支持其對(duì)任何資源的請(qǐng)求。502作為網(wǎng)關(guān)或者代理工作的服務(wù)器嘗試執(zhí)行請(qǐng)求時(shí),從上游服務(wù)器接收到無效的響應(yīng)。503由于臨時(shí)的服務(wù)器維護(hù)或者過載,服務(wù)器當(dāng)前無法處理請(qǐng)求。這個(gè)狀況是臨時(shí)的,并且將在一段時(shí)間以后恢復(fù)。如果能夠預(yù)計(jì)延遲時(shí)間,那么響應(yīng)中可以包含一個(gè) Retry-After 頭用以標(biāo)明這個(gè)延遲時(shí)間。如果沒有給出這個(gè) Retry-After 信息,那么客戶端應(yīng)當(dāng)以處理500響應(yīng)的方式處理它。 注意:503狀態(tài)碼的存在并不意味著服務(wù)器在過載的時(shí)候必須使用它。某些服務(wù)器只不過是希望拒絕客戶端的連接。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ù)器無法存儲(chǔ)完成請(qǐng)求所必須的內(nèi)容。這個(gè)狀況被認(rèn)為是臨時(shí)的。WebDAV (RFC 4918)509服務(wù)器達(dá)到帶寬限制。這不是一個(gè)官方的狀態(tài)碼,但是仍被廣泛使用。510獲取資源所需要的策略并沒有沒滿足。(RFC 2774)

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

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

以上就是前端開發(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精品国产乱码久久久久久久久 | 午夜在线观看视频网站 | av国产片| 成人午夜精品久久久久久久3d | 爽爽淫人综合网网站 | 羞羞视频免费视频欧美 | 久久久久久久久久久影视 | 二区三区四区视频 | 日本在线播放一区二区 | 久久久线视频 | 亚洲天堂在线电影 | 亚洲精品aaaaa | 欧美激情猛片xxxⅹ大3 | 成人午夜免费网站 | 成人国产精品一区 | 免看黄大片aa | 911网站大全在线观看 | 亚洲精品一区二区三区在线看 | 狠狠干91 | 国产精品久久久久久久久久久天堂 | 色婷婷tv| 成人午夜在线免费视频 | 国产精品一区二区三区在线 | 操操日日 | 福利在线免费 | 人成免费a级毛片 | 国产成年人视频 | 亚洲精品欧美二区三区中文字幕 | 视频一区 在线 | 欧美性精品videofree | 九九热在线精品视频 | 成人黄色小视频网站 | 爱操影视 | 五月天影院,久久综合, | 黄色久| 久久精品爱 | hdbbwsexvideo|