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

首頁 > 編程 > C# > 正文

深入HTTP head的使用詳解

2020-01-24 03:19:04
字體:
來源:轉載
供稿:網友
HTTP(HyperTextTransferProtocol)是超文本傳輸協議的縮寫,它用于傳送WWW方式的數據,關于HTTP協議的詳細內容請參考RFC2616。HTTP協議采用了請求/響應模型。客戶端向服務器發送一個請求,請求頭包含請求的方法、URI、協議版本、以及包含請求修飾符、客戶信息和內容的類似于MIME的消息結構。服務器以一個狀態行作為響應,相應的內容包括消息協議的版本,成功或者錯誤編碼加上包含服務器信息、實體元信息以及可能的實體內容。

通常HTTP消息包括客戶機向服務器的請求消息和服務器向客戶機的響應消息。這兩種類型的消息由一個起始行,一個或者多個頭域,一個只是頭域結束的空行和可選的消息體組成。HTTP的頭域包括通用頭,請求頭,響應頭和實體頭四個部分。每個頭域由一個域名,冒號(:)和域值三部分組成。域名是大小寫無關的,域值前可以添加任何數量的空格符,頭域可以被擴展為多行,在每行開始處,使用至少一個空格或制表符。 
通用頭域 
通用頭域包含請求和響應消息都支持的頭域,通用頭域包含Cache-Control、 Connection、Date、Pragma、Transfer-Encoding、Upgrade、Via。對通用頭域的擴展要求通訊雙方都支持此擴展,如果存在不支持的通用頭域,一般將會作為實體頭域處理。下面簡單介紹幾個在UPnP消息中使用的通用頭域。 
Cache-Control頭域 
Cache-Control指定請求和響應遵循的緩存機制。在請求消息或響應消息中設置 Cache-Control并不會修改另一個消息處理過程中的緩存處理過程。請求時的緩存指令包括no-cache、no-store、max-age、 max-stale、min-fresh、only-if-cached,響應消息中的指令包括public、private、no-cache、no- store、no-transform、must-revalidate、proxy-revalidate、max-age。各個消息中的指令含義如下: 
Public指示響應可被任何緩存區緩存。 
Private指示對于單個用戶的整個或部分響應消息,不能被共享緩存處理。這允許服務器僅僅描述當用戶的部分響應消息,此響應消息對于其他用戶的請求無效。 
no-cache指示請求或響應消息不能緩存 
no-store用于防止重要的信息被無意的發布。在請求消息中發送將使得請求和響應消息都不使用緩存。 
max-age指示客戶機可以接收生存期不大于指定時間(以秒為單位)的響應。 
min-fresh指示客戶機可以接收響應時間小于當前時間加上指定時間的響應。 
max-stale指示客戶機可以接收超出超時期間的響應消息。如果指定max-stale消息的值,那么客戶機可以接收超出超時期指定值之內的響應消息。 
Date頭域 
Date頭域表示消息發送的時間,時間的描述格式由rfc822定義。例如,Date:Mon,31Dec200104:25:57GMT。Date描述的時間表示世界標準時,換算成本地時間,需要知道用戶所在的時區。 
Pragma頭域 
Pragma頭域用來包含實現特定的指令,最常用的是Pragma:no-cache。在HTTP/1.1協議中,它的含義和Cache- Control:no-cache相同。 
請求消息 
請求消息的第一行為下面的格式: 
MethodSPRequest-URISPHTTP-VersionCRLFMethod 表示對于Request-URI完成的方法,這個字段是大小寫敏感的,包括OPTIONS、GET、HEAD、POST、PUT、DELETE、 TRACE。方法GET和HEAD應該被所有的通用WEB服務器支持,其他所有方法的實現是可選的。GET方法取回由Request-URI標識的信息。 HEAD方法也是取回由Request-URI標識的信息,只是可以在響應時,不返回消息體。POST方法可以請求服務器接收包含在請求中的實體信息,可以用于提交表單,向新聞組、BBS、郵件群組和數據庫發送消息。

SP表示空格。Request-URI遵循URI格式,在此字段為星號(*)時,說明請求并不用于某個特定的資源地址,而是用于服務器本身。HTTP- Version表示支持的HTTP版本,例如為HTTP/1.1。CRLF表示換行回車符。請求頭域允許客戶端向服務器傳遞關于請求或者關于客戶機的附加信息。請求頭域可能包含下列字段Accept、Accept-Charset、Accept- Encoding、Accept-Language、Authorization、From、Host、If-Modified-Since、If- Match、If-None-Match、If-Range、If-Range、If-Unmodified-Since、Max-Forwards、 Proxy-Authorization、Range、Referer、User-Agent。對請求頭域的擴展要求通訊雙方都支持,如果存在不支持的請求頭域,一般將會作為實體頭域處理。 
典型的請求消息: 
GET http://download.microtool.de:80/somedata.exe 
Host: download.microtool.de 
Accept:*/* 
Pragma: no-cache 
Cache-Control: no-cache 
Referer: http://download.microtool.de/ 
User-Agent:Mozilla/4.04[en](Win95;I;Nav) 
Range:bytes=554554- 
上例第一行表示HTTP客戶端(可能是瀏覽器、下載程序)通過GET方法獲得指定URL下的文件。棕色的部分表示請求頭域的信息,綠色的部分表示通用頭部分。 
Host頭域 
Host頭域指定請求資源的Intenet主機和端口號,必須表示請求url的原始服務器或網關的位置。HTTP/1.1請求必須包含主機頭域,否則系統會以400狀態碼返回。 
Referer頭域 
Referer頭域允許客戶端指定請求uri的源資源地址,這可以允許服務器生成回退鏈表,可用來登陸、優化cache等。他也允許廢除的或錯誤的連接由于維護的目的被追蹤。如果請求的uri沒有自己的uri地址,Referer不能被發送。如果指定的是部分uri地址,則此地址應該是一個相對地址。 
Range頭域 
Range頭域可以請求實體的一個或者多個子范圍。例如, 
表示頭500個字節:bytes=0-499 
表示第二個500字節:bytes=500-999 
表示最后500個字節:bytes=-500 
表示500字節以后的范圍:bytes=500- 
第一個和最后一個字節:bytes=0-0,-1 
同時指定幾個范圍:bytes=500-600,601-999 
但是服務器可以忽略此請求頭,如果無條件GET包含Range請求頭,響應會以狀態碼206(PartialContent)返回而不是以200 (OK)。 
User-Agent頭域 
User-Agent頭域的內容包含發出請求的用戶信息。 
響應消息 
響應消息的第一行為下面的格式: 
HTTP-VersionSPStatus-CodeSPReason-PhraseCRLF 
HTTP-Version表示支持的HTTP版本,例如為HTTP/1.1。Status- Code是一個三個數字的結果代碼。Reason-Phrase給Status-Code提供一個簡單的文本描述。Status-Code主要用于機器自動識別,Reason-Phrase主要用于幫助用戶理解。Status-Code的第一個數字定義響應的類別,后兩個數字沒有分類的作用。第一個數字可能取5個不同的值: 
1xx:信息響應類,表示接收到請求并且繼續處理 
2xx:處理成功響應類,表示動作被成功接收、理解和接受 
3xx:重定向響應類,為了完成指定的動作,必須接受進一步處理 
4xx:客戶端錯誤,客戶請求包含語法錯誤或者是不能正確執行 
5xx:服務端錯誤,服務器不能正確執行一個正確的請求 
響應頭域允許服務器傳遞不能放在狀態行的附加信息,這些域主要描述服務器的信息和 Request-URI進一步的信息。響應頭域包含Age、Location、Proxy-Authenticate、Public、Retry- After、Server、Vary、Warning、WWW-Authenticate。對響應頭域的擴展要求通訊雙方都支持,如果存在不支持的響應頭域,一般將會作為實體頭域處理。 
典型的響應消息: 
HTTP/1.0200OK 
Date:Mon,31Dec200104:25:57GMT 
Server:Apache/1.3.14(Unix) 
Content-type:text/html 
Last-modified:Tue,17Apr200106:46:28GMT 
Etag:"a030f020ac7c01:1e9f" 
Content-length:39725426 
Content-range:bytes554554-40279979/40279980 
上例第一行表示HTTP服務端響應一個GET方法。棕色的部分表示響應頭域的信息,綠色的部分表示通用頭部分,紅色的部分表示實體頭域的信息。 
Location響應頭 
Location響應頭用于重定向接收者到一個新URI地址。 
Server響應頭 
Server響應頭包含處理請求的原始服務器的軟件信息。此域能包含多個產品標識和注釋,產品標識一般按照重要性排序。 
實體 
請求消息和響應消息都可以包含實體信息,實體信息一般由實體頭域和實體組成。實體頭域包含關于實體的原信息,實體頭包括Allow、Content- Base、Content-Encoding、Content-Language、 Content-Length、Content-Location、Content-MD5、Content-Range、Content-Type、 Etag、Expires、Last-Modified、extension-header。extension-header允許客戶端定義新的實體頭,但是這些域可能無法未接受方識別。實體可以是一個經過編碼的字節流,它的編碼方式由Content-Encoding或Content-Type定義,它的長度由Content-Length或Content-Range定義。 
Content-Type實體頭 
Content-Type實體頭用于向接收方指示實體的介質類型,指定HEAD方法送到接收方的實體介質類型,或GET方法發送的請求介質類型 Content-Range實體頭 
Content-Range實體頭用于指定整個實體中的一部分的插入位置,他也指示了整個實體的長度。在服務器向客戶返回一個部分響應,它必須描述響應覆蓋的范圍和整個實體長度。一般格式: 
Content-Range:bytes-unitSPfirst-byte-pos-last-byte-pos/entity-legth 
例如,傳送頭500個字節次字段的形式:Content-Range:bytes0- 499/1234如果一個http消息包含此節(例如,對范圍請求的響應或對一系列范圍的重疊請求),Content-Range表示傳送的范圍, Content-Length表示實際傳送的字節數。 
Last-modified實體頭 
Last-modified實體頭指定服務器上保存內容的最后修訂時間。

應答頭 aaaaaaaaaaaaaaaaaaaaaaaaa說明
Allow服務器支持哪些請求方法(如GET、POST等)。
Content-Encoding文檔的編碼(Encode)方法。只有在解碼之后才可以得到Content-Type頭指定的內容類型。利用gzip壓縮文檔能夠顯著地減少HTML文檔的下載時間。Java的GZIPOutputStream可以很方便地進行gzip壓縮,但只有Unix上的Netscape和Windows上的IE 4、IE 5才支持它。因此,Servlet應該通過查看Accept-Encoding頭(即request.getHeader("Accept-Encoding"))檢查瀏覽器是否支持gzip,為支持gzip的瀏覽器返回經gzip壓縮的HTML頁面,為其他瀏覽器返回普通頁面。
Content-Length表示內容長度。只有當瀏覽器使用持久HTTP連接時才需要這個數據。如果你想要利用持久連接的優勢,可以把輸出文檔寫入ByteArrayOutputStram,完成后查看其大小,然后把該值放入Content-Length頭,最后通過byteArrayStream.writeTo(response.getOutputStream()發送內容。
Content-Type表示后面的文檔屬于什么MIME類型。Servlet默認為text/plain,但通常需要顯式地指定為text/html。由于經常要設置Content-Type,因此HttpServletResponse提供了一個專用的方法setContentTyep。 
Date當前的GMT時間。你可以用setDateHeader來設置這個頭以避免轉換時間格式的麻煩。
Expires應該在什么時候認為文檔已經過期,從而不再緩存它?
Last-Modified文檔的最后改動時間??蛻艨梢酝ㄟ^If-Modified-Since請求頭提供一個日期,該請求將被視為一個條件GET,只有改動時間遲于指定時間的文檔才會返回,否則返回一個304(Not Modified)狀態。Last-Modified也可用setDateHeader方法來設置。
Location表示客戶應當到哪里去提取文檔。Location通常不是直接設置的,而是通過HttpServletResponse的sendRedirect方法,該方法同時設置狀態代碼為302。
Refresh表示瀏覽器應該在多少時間之后刷新文檔,以秒計。除了刷新當前文檔之外,你還可以通過setHeader("Refresh", "5; URL=http://host/path")讓瀏覽器讀取指定的頁面。 
注意這種功能通常是通過設置HTML頁面HEAD區的<META HTTP-EQUIV="Refresh" CONTENT="5;URL=http://host/path">實現,這是因為,自動刷新或重定向對于那些不能使用CGI或Servlet的HTML編寫者十分重要。但是,對于Servlet來說,直接設置Refresh頭更加方便。 

注意Refresh的意義是“N秒之后刷新本頁面或訪問指定頁面”,而不是“每隔N秒刷新本頁面或訪問指定頁面”。因此,連續刷新要求每次都發送一個Refresh頭,而發送204狀態代碼則可以阻止瀏覽器繼續刷新,不管是使用Refresh頭還是<META HTTP-EQUIV="Refresh" ...>。 

注意Refresh頭不屬于HTTP 1.1正式規范的一部分,而是一個擴展,但Netscape和IE都支持它。
Server服務器名字。Servlet一般不設置這個值,而是由Web服務器自己設置。
Set-Cookie設置和頁面關聯的Cookie。Servlet不應使用response.setHeader("Set-Cookie", ...),而是應使用HttpServletResponse提供的專用方法addCookie。參見下文有關Cookie設置的討論。
WWW-Authenticate客戶應該在Authorization頭中提供什么類型的授權信息?在包含401(Unauthorized)狀態行的應答中這個頭是必需的。例如,response.setHeader("WWW-Authenticate", "BASIC realm=\"executives\"")。 
注意Servlet一般不進行這方面的處理,而是讓Web服務器的專門機制來控制受密碼保護頁面的訪問(例如.htaccess)。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
自拍偷拍亚洲精品| 青青精品视频播放| 国产亚洲日本欧美韩国| 欧美电影在线观看高清| 综合久久五月天| 亚洲精品免费在线视频| 亚洲毛茸茸少妇高潮呻吟| 色老头一区二区三区| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产成人亚洲综合91精品| 亚洲综合第一页| 亚洲午夜精品久久久久久久久久久久| 久久91亚洲精品中文字幕奶水| 国产亚洲精品激情久久| 国产精品一区av| 最近中文字幕日韩精品| 国产精品女主播| 国产精品日韩久久久久| 日韩美女在线播放| 98午夜经典影视| 日本不卡免费高清视频| 亚洲欧美日韩精品久久| 欧美精品videosex极品1| 爱福利视频一区| 亚洲综合日韩中文字幕v在线| 亚洲国产精品成人一区二区| 亚洲成人网在线观看| 午夜免费日韩视频| 欧美—级高清免费播放| 国产精品91视频| 中文字幕亚洲自拍| 91在线色戒在线| 国产精品黄页免费高清在线观看| 日韩有码在线电影| 在线成人激情黄色| 国产欧美精品xxxx另类| 日韩欧美一区二区三区久久| 久久久久久久激情视频| 中文字幕亚洲综合久久| 国产精品免费久久久| 亚洲日本欧美日韩高观看| 国产精品大片wwwwww| 国产精品久久久久久婷婷天堂| 欧美放荡办公室videos4k| 中文字幕在线观看日韩| 欧美一区二区三区精品电影| 亚洲欧美国产另类| 亚洲欧洲在线播放| 国产一区欧美二区三区| 国产精品免费久久久久久| 中文字幕一区二区三区电影| 国产精品美女免费| 欧美日韩激情小视频| 97国产精品人人爽人人做| 国产成人在线精品| 国产精品高清免费在线观看| 国产精品免费视频xxxx| 欧美网站在线观看| 啪一啪鲁一鲁2019在线视频| 最近2019中文免费高清视频观看www99| 久久久999国产精品| 日韩视频欧美视频| 日韩美女写真福利在线观看| 中文字幕亚洲欧美日韩2019| 欧美色播在线播放| 亚洲第一网站男人都懂| 91精品国产自产91精品| 国产成人福利视频| 国产91精品网站| 亚洲高清av在线| 亚洲人成网站777色婷婷| 国产视频久久网| 91亚洲国产成人久久精品网站| 日韩av在线最新| 97精品久久久中文字幕免费| 91精品在线一区| 亚洲高清福利视频| 欧美极品xxxx| 亚洲奶大毛多的老太婆| 欧美日韩成人免费| 欧美精品在线免费播放| 日韩电影视频免费| 国产香蕉精品视频一区二区三区| 久久精品国产96久久久香蕉| 欧美另类精品xxxx孕妇| 视频一区视频二区国产精品| 亚洲大胆人体av| 91国在线精品国内播放| 国产精品丝袜久久久久久高清| 亚洲最大的av网站| 欧美激情a∨在线视频播放| 亚洲精美色品网站| 欧美精品在线免费| 日本精品视频在线播放| 92看片淫黄大片欧美看国产片| 亚洲淫片在线视频| 欧美影院成年免费版| 欧美激情视频网站| 欧美亚洲午夜视频在线观看| 美女扒开尿口让男人操亚洲视频网站| 欧美在线视频播放| 亚洲精品影视在线观看| 国产精品一区专区欧美日韩| 成人美女av在线直播| 国产91精品在线播放| 精品视频在线观看日韩| 国内外成人免费激情在线视频| 日韩免费观看视频| 国产日韩欧美日韩| 国产精品自产拍在线观看中文| 日本精品中文字幕| 成人黄色av网站| 九九久久久久99精品| 精品视频在线导航| 中文字幕av一区二区| 久久久久久国产精品| 欧美电影《睫毛膏》| 日韩毛片中文字幕| 国产伊人精品在线| 成人福利视频网| 欧美巨乳在线观看| 日韩av色在线| 亚洲欧美激情四射在线日| 91国内揄拍国内精品对白| 成人网页在线免费观看| 成人欧美一区二区三区黑人孕妇| 亚洲综合日韩中文字幕v在线| 北条麻妃久久精品| 亚洲人成绝费网站色www| 亚洲色图校园春色| 亚州国产精品久久久| 性欧美激情精品| 欧美日韩在线视频一区二区| 亚洲老头老太hd| 国产va免费精品高清在线| 久久综合色影院| 亚洲三级黄色在线观看| 久久国产精品久久久| 国产精品美女视频网站| 欧美人与性动交| 91精品啪在线观看麻豆免费| 日韩在线观看免费全集电视剧网站| 欧美精品一区在线播放| 国产精品∨欧美精品v日韩精品| 国产午夜一区二区| 色无极亚洲影院| 日韩欧美有码在线| 日韩精品免费综合视频在线播放| 亚洲欧美国产日韩中文字幕| 欧美另类69精品久久久久9999| 亚洲乱码一区av黑人高潮| 这里精品视频免费| 欧美重口另类videos人妖| 国产精品日日做人人爱| 国产区亚洲区欧美区| 国语自产精品视频在线看抢先版图片| 精品国产一区二区三区四区在线观看| 亚洲乱码国产乱码精品精天堂| 亚洲国产91精品在线观看| 精品一区二区三区四区| 久久在精品线影院精品国产| 日韩中文字幕视频| 成人免费观看a| 精品久久久久久中文字幕大豆网|