溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

前端開(kāi)發(fā)中http協(xié)議是什么

發(fā)布時(shí)間:2020-12-02 10:47:41 來(lái)源:億速云 閱讀:178 作者:小新 欄目:web開(kāi)發(fā)

這篇文章給大家分享的是有關(guān)前端開(kāi)發(fā)中http協(xié)議是什么的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧。

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ì)象,如圖片,js文件,css文件等,則需要建立多次鏈接,這其中就會(huì)導(dǎo)致多次建立/斷開(kāi)連接的開(kāi)銷(xiā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è)域感覺(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é)省帶寬。

具體流程:客戶(hù)端——發(fā)送帶有100狀態(tài)碼的請(qǐng)求頭——服務(wù)端確認(rèn)是否能響應(yīng),如果不能,返回相應(yīng)狀態(tài)碼(如401,未認(rèn)證),如果能,則返回100狀態(tài)碼——客戶(hù)端根據(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查詢(xún)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指定客戶(hù)端能夠接收的內(nèi)容類(lèi)型Accept: text/plain, text/html
Accept-Charset瀏覽器可以接受的字符編碼集。Accept-Charset: iso-8859-5
Accept-Encoding指定瀏覽器可以支持的web服務(wù)器返回內(nèi)容壓縮編碼類(lèi)型。Accept-Encoding: compress, gzip
Accept-Language瀏覽器可接受的語(yǔ)言Accept-Language: en,zh
Accept-Ranges可以請(qǐng)求網(wǎng)頁(yè)實(shí)體的一個(gè)或者多個(gè)子范圍字段Accept-Ranges: bytes
AuthorizationHTTP授權(quán)的授權(quán)證書(shū)Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
Cache-Control指定請(qǐng)求和響應(yīng)遵循的緩存機(jī)制Cache-Control: no-cache
Connection表示是否需要持久連接。(HTTP 1.1默認(rèn)進(jìn)行持久連接)Connection: close
CookieHTTP請(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: 348
Content-Type請(qǐng)求的與實(shí)體對(duì)應(yīng)的MIME信息Content-Type: application/x-www-form-urlencoded
Date請(qǐng)求發(fā)送的日期和時(shí)間Date: Tue, 15 Nov 2010 08:12:31 GMT
Expect請(qǐng)求的特定的服務(wù)器行為Expect: 100-continue
From發(fā)出請(qǐng)求的用戶(hù)的EmailFrom: user@email.com
Host指定請(qǐng)求的服務(wù)器的域名和端口號(hào)Host: www.zcmhi.com
If-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 GMT
If-None-Match如果內(nèi)容未改變返回304代碼,參數(shù)為服務(wù)器先前發(fā)送的Etag,與服務(wù)器回應(yīng)的Etag比較判斷是否改變If-None-Match: “737060cd8c284d8af7ad3082f209582d”
If-Range如果實(shí)體未改變,服務(wù)器發(fā)送客戶(hù)端丟失的部分,否則發(fā)送整個(gè)實(shí)體。參數(shù)也為EtagIf-Range: “737060cd8c284d8af7ad3082f209582d”
If-Unmodified-Since只在實(shí)體在指定時(shí)間之后未被修改才請(qǐng)求成功If-Unmodified-Since: Sat, 29 Oct 2010 19:43:31 GMT
Max-Forwards限制信息通過(guò)代理和網(wǎng)關(guān)傳送的時(shí)間Max-Forwards: 10
Pragma用來(lái)包含實(shí)現(xiàn)特定的指令Pragma: no-cache
Proxy-Authorization連接到代理的授權(quán)證書(shū)Proxy-Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
Range只請(qǐng)求實(shí)體的一部分,指定范圍Range: bytes=500-999
Referer先前網(wǎng)頁(yè)的地址,當(dāng)前請(qǐng)求網(wǎng)頁(yè)緊隨其后,即來(lái)路Referer: http://www.zcmhi.com/archives/71.html
TE客戶(hù)端愿意接受的傳輸編碼,并通知服務(wù)器接受接受尾加頭信息TE: trailers,deflate;q=0.5
Upgrade向服務(wù)器指定某種傳輸協(xié)議以便服務(wù)器進(jìn)行轉(zhuǎn)換(如果支持)Upgrade: HTTP/2.0, SHTTP/1.3, IRC/6.9, RTA/x11
User-AgentUser-Agent的內(nèi)容包含發(fā)出請(qǐng)求的用戶(hù)信息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)求及哪種類(lèi)型的分段請(qǐng)求Accept-Ranges: bytes
Age從原始服務(wù)器到代理緩存形成的估算時(shí)間(以秒計(jì),非負(fù))Age: 12
Allow對(duì)某網(wǎng)絡(luò)資源的有效的請(qǐng)求行為,不允許則返回405Allow: GET, HEAD
Cache-Control告訴所有的緩存機(jī)制是否可以緩存及哪種類(lèi)型Cache-Control: no-cache
Content-Encodingweb服務(wù)器支持的返回內(nèi)容壓縮編碼類(lèi)型。Content-Encoding: gzip
Content-Language響應(yīng)體的語(yǔ)言Content-Language: en,zh
Content-Length響應(yīng)體的長(zhǎng)度Content-Length: 348
Content-Location請(qǐng)求資源可替代的備用的另一地址Content-Location: /index.htm
Content-MD5返回資源的MD5校驗(yàn)值Content-MD5: Q2hlY2sgSW50ZWdyaXR5IQ==
Content-Range在整個(gè)返回體中本部分的字節(jié)位置Content-Range: bytes 21010-47021/47022
Content-Type返回內(nèi)容的MIME類(lèi)型Content-Type: text/html; charset=utf-8
Date原始服務(wù)器消息發(fā)出的時(shí)間Date: Tue, 15 Nov 2010 08:12:31 GMT
ETag請(qǐng)求變量的實(shí)體標(biāo)簽的當(dāng)前值ETag: “737060cd8c284d8af7ad3082f209582d”
Expires響應(yīng)過(guò)期的日期和時(shí)間Expires: Thu, 01 Dec 2010 16:00:00 GMT
Last-Modified請(qǐng)求資源的最后修改時(shí)間Last-Modified: Tue, 15 Nov 2010 12:45:26 GMT
Location用來(lái)重定向接收方到非請(qǐng)求URL的位置來(lái)完成請(qǐng)求或標(biāo)識(shí)新的資源Location: http://www.zcmhi.com/archives/94.html
Pragma包括實(shí)現(xiàn)特定的指令,它可應(yīng)用到響應(yīng)鏈上的任何接收方Pragma: no-cache
Proxy-Authenticate它指出認(rèn)證方案和可應(yīng)用到代理的該URL上的參數(shù)Proxy-Authenticate: Basic
refresh應(yīng)用于重定向或一個(gè)新的資源被創(chuàng)造,在5秒之后重定向(由網(wǎng)景提出,被大部分瀏覽器支持)

Refresh: 5; url=

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

Retry-After如果實(shí)體暫時(shí)不可取,通知客戶(hù)端在指定時(shí)間之后再次嘗試Retry-After: 120
Serverweb服務(wù)器軟件名稱(chēng)Server: Apache/1.3.27 (Unix) (Red-Hat/Linux)
Set-Cookie設(shè)置Http CookieSet-Cookie: UserID=JohnDoe; Max-Age=3600; Version=1
Trailer指出頭域在分塊傳輸編碼的尾部存在Trailer: Max-Forwards
Transfer-Encoding文件傳輸編碼Transfer-Encoding:chunked
Vary告訴下游代理是使用緩存響應(yīng)還是從原始服務(wù)器請(qǐng)求Vary: *
Via告知代理客戶(hù)端響應(yīng)是通過(guò)哪里發(fā)送的Via: 1.0 fred, 1.1 nowhere.com (Apache/1.1)
Warning警告實(shí)體可能存在的問(wèn)題Warning: 199 Miscellaneous warning
WWW-Authenticate表明客戶(hù)端請(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)求查詢(xún)服務(wù)器的性能,或者查詢(xún)與資源相關(guān)的選項(xiàng)和需求

6. 狀態(tài)碼

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

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

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

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

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

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

  4XX  客戶(hù)端錯(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)碼英文名稱(chēng)中文描述
1開(kāi)頭的狀態(tài)碼
100Continue繼續(xù)??蛻?hù)端應(yīng)繼續(xù)其請(qǐng)求
101Switching Protocols切換協(xié)議。服務(wù)器根據(jù)客戶(hù)端的請(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ù)器處理成功,用戶(hù)終端(例如:瀏覽器)應(yīng)重置文檔視圖。可通過(guò)此返回碼清除瀏覽器的表單域
206Partial Content部分內(nèi)容。服務(wù)器成功處理了部分GET請(qǐng)求
3開(kāi)頭的狀態(tài)碼
300Multiple Choices多種選擇。請(qǐng)求的資源可包括多個(gè)位置,相應(yīng)可返回一個(gè)資源特征與地址的列表用于用戶(hù)終端(例如:瀏覽器)選擇
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類(lèi)似。但資源只是臨時(shí)被移動(dòng)。客戶(hù)端應(yīng)繼續(xù)使用原有URI
303See Other查看其它地址。與301類(lèi)似。使用GET和POST請(qǐng)求查看
304Not Modified未修改。所請(qǐng)求的資源未修改,服務(wù)器返回此狀態(tài)碼時(shí),不會(huì)返回任何資源??蛻?hù)端通常會(huì)緩存訪(fǎng)問(wèn)過(guò)的資源,通過(guò)提供一個(gè)頭信息指出客戶(hù)端希望只返回在指定日期之后修改的資源
305Use Proxy使用代理。所請(qǐng)求的資源必須通過(guò)代理訪(fǎng)問(wèn)
306Unused已經(jīng)被廢棄的HTTP狀態(tài)碼
307Temporary Redirect臨時(shí)重定向。與302類(lèi)似。使用GET請(qǐng)求重定向
4開(kāi)頭的狀態(tài)碼
400Bad Request客戶(hù)端請(qǐng)求的語(yǔ)法錯(cuò)誤,服務(wù)器無(wú)法理解
401Unauthorized請(qǐng)求要求用戶(hù)的身份認(rèn)證
402Payment Required保留,將來(lái)使用
403Forbidden服務(wù)器理解請(qǐng)求客戶(hù)端的請(qǐng)求,但是拒絕執(zhí)行此請(qǐng)求
404Not Found服務(wù)器無(wú)法根據(jù)客戶(hù)端的請(qǐng)求找到資源(網(wǎng)頁(yè))。通過(guò)此代碼,網(wǎng)站設(shè)計(jì)人員可設(shè)置"您所請(qǐng)求的資源無(wú)法找到"的個(gè)性頁(yè)面
405Method Not Allowed客戶(hù)端請(qǐng)求中的方法被禁止
406Not Acceptable服務(wù)器無(wú)法根據(jù)客戶(hù)端請(qǐng)求的內(nèi)容特性完成請(qǐng)求
407Proxy Authentication Required請(qǐng)求要求代理的身份認(rèn)證,與401類(lèi)似,但請(qǐng)求者應(yīng)當(dāng)使用代理進(jìn)行授權(quán)
408Request Time-out服務(wù)器等待客戶(hù)端發(fā)送的請(qǐng)求時(shí)間過(guò)長(zhǎng),超時(shí)
409Conflict服務(wù)器完成客戶(hù)端的PUT請(qǐng)求是可能返回此代碼,服務(wù)器處理請(qǐng)求時(shí)發(fā)生了沖突
410Gone客戶(hù)端請(qǐng)求的資源已經(jīng)不存在。410不同于404,如果資源以前有現(xiàn)在被永久刪除了可使用410代碼,網(wǎng)站設(shè)計(jì)人員可通過(guò)301代碼指定資源的新位置
411Length Required服務(wù)器無(wú)法處理客戶(hù)端發(fā)送的不帶Content-Length的請(qǐng)求信息
412Precondition Failed客戶(hù)端請(qǐng)求信息的先決條件錯(cuò)誤
413Request Entity Too Large由于請(qǐng)求的實(shí)體過(guò)大,服務(wù)器無(wú)法處理,因此拒絕請(qǐng)求。為防止客戶(hù)端的連續(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客戶(hù)端請(qǐng)求的范圍無(wú)效
417Expectation Failed服務(wù)器無(wú)法滿(mǎn)足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ú)法處理客戶(hù)端的請(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客戶(hù)端應(yīng)當(dāng)繼續(xù)發(fā)送請(qǐng)求。這個(gè)臨時(shí)響應(yīng)是用來(lái)通知客戶(hù)端它的部分請(qǐng)求已經(jīng)被服務(wù)器接收,且仍未被拒絕??蛻?hù)端應(yīng)當(dāng)繼續(xù)發(fā)送請(qǐng)求的剩余部分,或者如果請(qǐng)求已經(jīng)完成,忽略這個(gè)響應(yīng)。服務(wù)器必須在請(qǐng)求完成后向客戶(hù)端發(fā)送一個(gè)最終響應(yīng)。
101服務(wù)器已經(jīng)理解了客戶(hù)端的請(qǐng)求,并將通過(guò)Upgrade 消息頭通知客戶(hù)端采用不同的協(xié)議來(lái)完成這個(gè)請(qǐng)求。在發(fā)送完這個(gè)響應(yīng)最后的空行后,服務(wù)器將會(huì)切換到在Upgrade 消息頭中定義的那些協(xié)議。   只有在切換新的協(xié)議更有好處的時(shí)候才應(yīng)該采取類(lèi)似措施。例如,切換到新的HTTP 版本比舊版本更有優(yōu)勢(shì),或者切換到一個(gè)實(shí)時(shí)且同步的協(xié)議以傳送利用此類(lèi)特性的資源。
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í)建立的話(huà),應(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í)行一次的基于批處理的操作),而不必讓客戶(hù)端一直保持與服務(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è)的指針,以便用戶(hù)能夠估計(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)。   如果客戶(hù)端是瀏覽器的話(huà),那么用戶(hù)瀏覽器應(yīng)保留發(fā)送了該請(qǐng)求的頁(yè)面,而不產(chǎn)生任何文檔視圖上的變化,即使按照規(guī)范新的或更新后的元信息應(yīng)當(dāng)被應(yīng)用到用戶(hù)瀏覽器活動(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)主要是被用于接受用戶(hù)輸入后,立即重置表單,以便用戶(hù)能夠輕松地開(kāi)始另一次輸入。   與204響應(yīng)一樣,該響應(yīng)也被禁止包含任何消息體,且以消息頭后的第一個(gè)空行結(jié)束。
206服務(wù)器已經(jīng)成功處理了部分 GET 請(qǐng)求。類(lèi)似于 FlashGet 或者迅雷這類(lèi)的 HTTP 下載工具都是使用此類(lèi)響應(yīng)實(shí)現(xiàn)斷點(diǎn)續(xù)傳或者將一個(gè)大文檔分解為多個(gè)下載段同時(shí)下載。   該請(qǐng)求必須包含 Range 頭信息來(lái)指示客戶(hù)端希望得到的內(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)的值不同的話(huà)。   假如本響應(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 頭部不能精確匹配的話(huà),則客戶(hù)端緩存應(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)的商議信息。用戶(hù)或?yàn)g覽器能夠自行選擇一個(gè)首選的地址進(jìn)行重定向。   除非這是一個(gè) HEAD 請(qǐng)求,否則該響應(yīng)應(yīng)當(dāng)包括一個(gè)資源特性及地址的列表的實(shí)體,以便用戶(hù)或?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 之一。如果可能,擁有鏈接編輯功能的客戶(hù)端應(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)行重定向,除非得到用戶(hù)的確認(rèn),因?yàn)檎?qǐng)求的條件可能因此發(fā)生變化。   注意:對(duì)于某些使用 HTTP/1.0 協(xié)議的瀏覽器,當(dāng)它們發(fā)送的 POST 請(qǐng)求得到了一個(gè)301響應(yīng)的話(huà),接下來(lái)的重定向請(qǐng)求將會(huì)變成 GET 方式。
302請(qǐng)求的資源現(xiàn)在臨時(shí)從不同的 URI 響應(yīng)請(qǐng)求。由于這樣的重定向是臨時(shí)的,客戶(hù)端應(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)行重定向,除非得到用戶(hù)的確認(rèn),因?yàn)檎?qǐng)求的條件可能因此發(fā)生變化。   注意:雖然RFC 1945和RFC 2068規(guī)范不允許客戶(hù)端在重定向時(shí)改變請(qǐng)求的方法,但是很多現(xiàn)存的瀏覽器將302響應(yīng)視作為303響應(yīng),并且使用 GET 方式訪(fǎng)問(wèn)在 Location 中規(guī)定的 URI,而無(wú)視原先請(qǐng)求的方法。狀態(tài)碼303和307被添加了進(jìn)來(lái),用以明確服務(wù)器期待客戶(hù)端進(jìn)行何種反應(yīng)。
303對(duì)應(yīng)當(dāng)前請(qǐng)求的響應(yīng)可以在另一個(gè) URI 上被找到,而且客戶(hù)端應(yīng)當(dāng)采用 GET 的方式訪(fǎng)問(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ī)范要求客戶(hù)端處理303響應(yīng)時(shí)應(yīng)當(dāng)做的。
304如果客戶(hù)端發(fā)送了一個(gè)帶條件的 GET 請(qǐng)求且該請(qǐng)求已被允許,而文檔的內(nèi)容(自上次訪(fǎng)問(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ù)器以及客戶(hù)端可以自行將 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)的值不同的話(huà)。   假如本響應(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ò)指定的代理才能被訪(fǎng)問(wèn)。Location 域中將給出指定的代理所在的 URI 信息,接收者需要重復(fù)發(fā)送一個(gè)單獨(dú)的請(qǐng)求,通過(guò)這個(gè)代理才能訪(fǎng)問(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í)的,客戶(hù)端應(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),因此需要添加上述必要信息以便用戶(hù)能夠理解并向新的 URI 發(fā)出訪(fǎng)問(wèn)請(qǐng)求。   如果這不是一個(gè)GET 或者 HEAD 請(qǐng)求,那么瀏覽器禁止自動(dòng)進(jìn)行重定向,除非得到用戶(hù)的確認(rèn),因?yàn)檎?qǐng)求的條件可能因此發(fā)生變化。
4001、語(yǔ)義有誤,當(dāng)前請(qǐng)求無(wú)法被服務(wù)器理解。除非進(jìn)行修改,否則客戶(hù)端不應(yīng)該重復(fù)提交這個(gè)請(qǐng)求。   2、請(qǐng)求參數(shù)有誤。
401當(dāng)前請(qǐng)求需要用戶(hù)驗(yàn)證。該響應(yīng)必須包含一個(gè)適用于被請(qǐng)求資源的 WWW-Authenticate 信息頭用以詢(xún)問(wèn)用戶(hù)信息??蛻?hù)端可以重復(fù)提交一個(gè)包含恰當(dāng)?shù)?Authorization 頭信息的請(qǐng)求。如果當(dāng)前請(qǐng)求已經(jīng)包含了 Authorization 證書(shū),那么401響應(yīng)代表著服務(wù)器驗(yàn)證已經(jīng)拒絕了那些證書(shū)。如果401響應(yīng)包含了與前一個(gè)響應(yīng)相同的身份驗(yàn)證詢(xún)問(wèn),且瀏覽器已經(jīng)至少?lài)L試了一次驗(yàn)證,那么瀏覽器應(yīng)當(dāng)向用戶(hù)展示響應(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),假如它不希望讓客戶(hù)端獲得任何信息。
404請(qǐng)求失敗,請(qǐng)求所希望得到的資源未被在服務(wù)器上發(fā)現(xiàn)。沒(méi)有信息能夠告訴用戶(hù)這個(gè)狀況到底是暫時(shí)的還是永久的。假如服務(wù)器知道情況的話(huà),應(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)行寫(xiě)操作,因而絕大部分的網(wǎng)頁(yè)服務(wù)器都不支持或者在默認(rèn)配置下不允許上述請(qǐng)求方法,對(duì)于此類(lèi)請(qǐng)求均會(huì)返回405錯(cuò)誤。
406請(qǐng)求的資源的內(nèi)容特性無(wú)法滿(mǎn)足請(qǐng)求頭中的條件,因而無(wú)法生成響應(yīng)實(shí)體。   除非這是一個(gè) HEAD 請(qǐng)求,否則該響應(yīng)就應(yīng)當(dāng)返回一個(gè)包含可以讓用戶(hù)或者瀏覽器從中選擇最合適的實(shí)體特性以及地址列表的實(shí)體。實(shí)體的格式由 Content-Type 頭中定義的媒體類(lèi)型決定。瀏覽器可以根據(jù)格式及自身能力自行作出最佳選擇。但是,規(guī)范中并沒(méi)有定義任何作出此類(lèi)自動(dòng)選擇的標(biāo)準(zhǔn)。
407與401響應(yīng)類(lèi)似,只不過(guò)客戶(hù)端必須在代理服務(wù)器上進(jìn)行身份驗(yàn)證。代理服務(wù)器必須返回一個(gè) Proxy-Authenticate 用以進(jìn)行身份詢(xún)問(wèn)??蛻?hù)端可以返回一個(gè) Proxy-Authorization 信息頭用以驗(yàn)證。參見(jiàn)RFC 2617。
408請(qǐng)求超時(shí)??蛻?hù)端沒(méi)有在服務(wù)器預(yù)備等待的時(shí)間內(nèi)完成一個(gè)請(qǐng)求的發(fā)送??蛻?hù)端可以隨時(shí)再次提交這一請(qǐng)求而無(wú)需進(jìn)行任何更改。
409由于和被請(qǐng)求的資源的當(dāng)前狀態(tài)之間存在沖突,請(qǐng)求無(wú)法完成。這個(gè)代碼只允許用在這樣的情況下才能被使用:用戶(hù)被認(rèn)為能夠解決沖突,并且會(huì)重新提交新的請(qǐng)求。該響應(yīng)應(yīng)當(dāng)包含足夠的信息以便用戶(hù)發(fā)現(xiàn)沖突的源頭。   沖突通常發(fā)生于對(duì) PUT 請(qǐng)求的處理中。例如,在采用版本檢查的環(huán)境下,某次 PUT 提交的對(duì)特定資源的修改請(qǐng)求所附帶的版本信息與之前的某個(gè)(第三方)請(qǐng)求向沖突,那么此時(shí)服務(wù)器就應(yīng)該返回一個(gè)409錯(cuò)誤,告知用戶(hù)請(qǐng)求無(wú)法完成。此時(shí),響應(yīng)實(shí)體中很可能會(huì)包含兩個(gè)沖突版本之間的差異比較,以便用戶(hù)重新提交歸并以后的新版本。
410被請(qǐng)求的資源在服務(wù)器上已經(jīng)不再可用,而且沒(méi)有任何已知的轉(zhuǎn)發(fā)地址。這樣的狀況應(yīng)當(dāng)被認(rèn)為是永久性的。如果可能,擁有鏈接編輯功能的客戶(hù)端應(yīng)當(dāng)在獲得用戶(hù)許可后刪除所有指向這個(gè)地址的引用。如果服務(wù)器不知道或者無(wú)法確定這個(gè)狀況是否是永久的,那么就應(yīng)該使用404狀態(tài)碼。除非額外說(shuō)明,否則這個(gè)響應(yīng)是可緩存的。   410響應(yīng)的目的主要是幫助網(wǎng)站管理員維護(hù)網(wǎng)站,通知用戶(hù)該資源已經(jīng)不再可用,并且服務(wù)器擁有者希望所有指向這個(gè)資源的遠(yuǎn)端連接也被刪除。這類(lèi)事件在限時(shí)、增值服務(wù)中很普遍。同樣,410響應(yīng)也被用于通知客戶(hù)端在當(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 頭之后,客戶(hù)端可以再次提交該請(qǐng)求。
412服務(wù)器在驗(yàn)證在請(qǐng)求的頭字段中給出先決條件時(shí),沒(méi)能滿(mǎn)足其中的一個(gè)或多個(gè)。這個(gè)狀態(tài)碼允許客戶(hù)端在獲取資源時(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)閉連接以免客戶(hù)端繼續(xù)發(fā)送此請(qǐng)求。   如果這個(gè)狀況是臨時(shí)的,服務(wù)器應(yīng)當(dāng)返回一個(gè) Retry-After 的響應(yīng)頭,以告知客戶(hù)端可以在多少時(shí)間以后重新嘗試。
414請(qǐng)求的URI 長(zhǎng)度超過(guò)了服務(wù)器能夠解釋的長(zhǎng)度,因此服務(wù)器拒絕對(duì)該請(qǐng)求提供服務(wù)。這比較少見(jiàn),通常的情況包括:   本應(yīng)使用POST方法的表單提交變成了GET方法,導(dǎo)致查詢(xún)字符串(Query String)過(guò)長(zhǎng)。   重定向URI “黑洞”,例如每次重定向把舊的 URI 作為新的 URI 的一部分,導(dǎo)致在若干次重定向后 URI 超長(zhǎng)。   客戶(hù)端正在嘗試?yán)媚承┓?wù)器中存在的安全漏洞攻擊服務(wù)器。這類(lèi)服務(wù)器使用固定長(zhǎng)度的緩沖讀取或操作請(qǐng)求的 URI,當(dāng) GET 后的參數(shù)超過(guò)某個(gè)數(shù)值后,可能會(huì)產(chǎn)生緩沖區(qū)溢出,導(dǎo)致任意代碼被執(zhí)行[1]。沒(méi)有此類(lè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ù)器滿(mǎn)足,或者這個(gè)服務(wù)器是一個(gè)代理服務(wù)器,它有明顯的證據(jù)證明在當(dāng)前路由的下一個(gè)節(jié)點(diǎn)上,Expect 的內(nèi)容無(wú)法被滿(mǎn)足。
421從當(dāng)前客戶(hù)端所在的IP地址到服務(wù)器的連接數(shù)超過(guò)了服務(wù)器許可的最大范圍。通常,這里的IP地址指的是從服務(wù)器上看到的客戶(hù)端地址(比如用戶(hù)的網(wǎng)關(guān)或者代理服務(wù)器地址)。在這種情況下,連接數(shù)的計(jì)算可能涉及到不止一個(gè)終端用戶(hù)。
422從當(dāng)前客戶(hù)端所在的IP地址到服務(wù)器的連接數(shù)超過(guò)了服務(wù)器許可的最大范圍。通常,這里的IP地址指的是從服務(wù)器上看到的客戶(hù)端地址(比如用戶(hù)的網(wǎng)關(guān)或者代理服務(wù)器地址)。在這種情況下,連接數(shù)的計(jì)算可能涉及到不止一個(gè)終端用戶(hù)。
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客戶(hù)端應(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 信息,那么客戶(hù)端應(yīng)當(dāng)以處理500響應(yīng)的方式處理它。   注意:503狀態(tài)碼的存在并不意味著服務(wù)器在過(guò)載的時(shí)候必須使用它。某些服務(wù)器只不過(guò)是希望拒絕客戶(hù)端的連接。
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查詢(xún)超時(shí)時(shí)會(huì)返回400或者500錯(cuò)誤
505服務(wù)器不支持,或者拒絕支持在請(qǐng)求中使用的 HTTP 版本。這暗示著服務(wù)器不能或不愿使用與客戶(hù)端相同的版本。響應(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)滿(mǎn)足。(RFC 2774)

感謝各位的閱讀!關(guān)于前端開(kāi)發(fā)中http協(xié)議是什么就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI