成人AV在线无码|婷婷五月激情色,|伊人加勒比二三四区|国产一区激情都市|亚洲AV无码电影|日av韩av无码|天堂在线亚洲Av|无码一区二区影院|成人无码毛片AV|超碰在线看中文字幕

IIS的主機頭值和HTTP頭

IIS 的主機頭值和HTTP 頭主機頭是綁定域名,沒有域名不用設(shè)置主機頭, 所謂的主機頭的叫法起自IIS 中對域名綁定的功能,一般的web 服務(wù)器一個ip 地址的80端口只能正確對應(yīng)一個網(wǎng)站,處理一個

IIS 的主機頭值和HTTP 頭

主機頭是綁定域名,沒有域名不用設(shè)置主機頭, 所謂的主機頭的叫法起自IIS 中對域名綁定的功能,一般的web 服務(wù)器一個ip 地址的80端口只能正確對應(yīng)一個網(wǎng)站,處理一個域名的訪問請求。而web 服務(wù)器在不使用多個ip 地址和端口的情況下,如果需要支持多個相對獨立的網(wǎng)站就需要一種機制來分辨同一個ip 地址上的不同網(wǎng)站的請求,這就出現(xiàn)了主機頭綁定的方法。簡單的說就是,將不同的網(wǎng)站空間對應(yīng)不同的域名,以連接請求中的域名字段來分發(fā)和應(yīng)答正確的對應(yīng)空間的文件執(zhí)行結(jié)果。舉個例子來說,一臺服務(wù)器ip 地址為192.168.1.10,有兩個域名和對應(yīng)的空間在這臺服務(wù)器上,使用的都是192.168.1.10的80端口來提供服務(wù)。如果只是簡單的將兩個域名A 和B 的域名記錄解析到這個ip 地址,那么web 服務(wù)器在收到任何請求時反饋的都會是同一個網(wǎng)站的信息,這顯然達不到要求。接下來我們使用主機頭綁定域名A 和B 到他們對應(yīng)的空間文件夾C 和D 。當含有域名A 的web 請求信息到達192.168.1.10時,web 服務(wù)器將執(zhí)行它對應(yīng)的空間C 中的首頁文件,并返回給客戶端,含有域名B 的web 請求信息同理,只不過解釋的是空間D 的文件。所以在使用主機頭綁定功能后就不能使用ip 地址訪問其上的任何網(wǎng)站了,因為請求信息中不存在域名信息,所以會出錯。

在IIS 中有一個叫主機頭的概念,我們基本都已經(jīng)掌握,還有一個叫HTTP 頭的概念,有的同學(xué)已經(jīng)問我這個問題,其實HTTP 頭更多的涉及到軟件上的東東。

最直觀的HTTP 頭就是當我們在FROTPAGE 或DREAMWEAVER 中每次新建一個HTML 頁面后,在這個頁面的代碼都會有這樣一行代碼:

其實這就是一個HTTP 頭信息,HTML 頁面開頭都會有類似的這樣一行代碼。 那么到底是么是HTTP 頭呢?HTTP 頭分為HTTP 請求頭和HTTP 應(yīng)答頭。HTTP 請求頭為HTTP 客戶在瀏覽服務(wù)器上的主頁時,向服務(wù)器發(fā)送請求的時候必須指明請求類型。請求類型是指HTTP-GET 或HTTP-POST ,每個HTTP-GET 和HTTP-POST 都由一系列HTTP 請求頭組成,這些請求頭定義了客戶端從服務(wù)器請求了什么,而響應(yīng)則是由一系列HTTP 應(yīng)答頭和應(yīng)答數(shù)據(jù)組成,如果請求成功則返回應(yīng)答。 我的理解:每次客戶端通過IE 向服務(wù)器請求訪問一個頁面時總是使用HTTP 的請求頭發(fā)送GET 類型或POST 類型的HTTP 請求頭. 服務(wù)器在發(fā)送應(yīng)答時,發(fā)送的是HTTP 應(yīng)答請求。

請求頭和應(yīng)答具體有哪些標識,我們不詳細講了,自己看以下內(nèi)容: HTTP 請求頭概述 (HttpServletRequest )

HTTP 客戶程序(例如瀏覽器),向服務(wù)器發(fā)送請求的時候必須指明請求類型(一般是GET 或者POST )。如有必要,客戶程序還可以選擇發(fā)送其他的請求頭。大多數(shù)請求頭并不是必需的,但Content-Length 除外。對于POST 請求來說Content-Length 必須出現(xiàn)。

下面是一些最常見的請求頭

,

Accept :瀏覽器可接受的MIME 類型。

Accept-Charset :瀏覽器可接受的字符集。

Accept-Encoding :瀏覽器能夠進行解碼的數(shù)據(jù)編碼方式,比如gzip 。Servlet 能夠向支持gzip 的瀏覽器返回經(jīng)gzip 編碼的HTML 頁面。許多情形下這可以減少5到10倍的下載時間。

Accept-Language :瀏覽器所希望的語言種類,當服務(wù)器能夠提供一種以上的語言版本時要用到。

Authorization :授權(quán)信息,通常出現(xiàn)在對服務(wù)器發(fā)送的WWW-Authenticate 頭的應(yīng)答中。

Connection :表示是否需要持久連接。如果Servlet 看到這里的值為

“Keep-Alive”,或者看到請求使用的是HTTP 1.1(HTTP 1.1默認進行持久連接),它就可以利用持久連接的優(yōu)點,當頁面包含多個元素時(例如Applet ,圖片),顯著地減少下載所需要的時間。要實現(xiàn)這一點,Servlet 需要在應(yīng)答中發(fā)送一個Content-Length 頭,最簡單的實現(xiàn)方法是:先把內(nèi)容寫入

ByteArrayOutputStream ,然后在正式寫出內(nèi)容之前計算它的大小。

Content-Length :表示請求消息正文的長度。

Cookie :這是最重要的請求頭信息之一

From :請求發(fā)送者的email 地址,由一些特殊的Web 客戶程序使用,瀏覽器不會用到它。

Host :初始URL 中的主機和端口。

If-Modified-Since :只有當所請求的內(nèi)容在指定的日期之后又經(jīng)過修改才返回它,否則返回304“Not Modified”應(yīng)答。

Pragma :指定“no-cache”值表示服務(wù)器必須返回一個刷新后的文檔,即使它是代理服務(wù)器而且已經(jīng)有了頁面的本地拷貝。

Referer :包含一個URL ,用戶從該URL 代表的頁面出發(fā)訪問當前請求的頁面。

User-Agent :瀏覽器類型,如果Servlet 返回的內(nèi)容與瀏覽器類型有關(guān)則該值非常有用。

UA-Pixels ,UA-Color ,UA-OS ,UA-CPU :由某些版本的IE 瀏覽器所發(fā)送的非標準的請求頭,表示屏幕大小、顏色深度、操作系統(tǒng)和CPU 類型。

,

有關(guān)HTTP 頭完整、詳細的說明,請參見http://www.w3.org/Protocols/的HTTP 規(guī)范。

HTTP 應(yīng)答頭概述(HttpServletResponse )

Web 服務(wù)器的HTTP 應(yīng)答一般由以下幾項構(gòu)成:一個狀態(tài)行,一個或多個應(yīng)答頭,一個空行,內(nèi)容文檔。設(shè)置HTTP 應(yīng)答頭往往和設(shè)置狀態(tài)行中的狀態(tài)代碼結(jié)合起來。例如,有好幾個表示“文檔位置已經(jīng)改變”的狀態(tài)代碼都伴隨著一個

Location 頭,而401(Unauthorized )狀態(tài)代碼則必須伴隨一個WWW-Authenticate 頭。

然而,即使在沒有設(shè)置特殊含義的狀態(tài)代碼時,指定應(yīng)答頭也是很有用的。應(yīng)答頭可以用來完成:設(shè)置Cookie ,指定修改日期,指示瀏覽器按照指定的間隔刷新頁面,聲明文檔的長度以便利用持久HTTP 連接,??等等許多其他任務(wù)。

設(shè)置應(yīng)答頭最常用的方法是HttpServletResponse 的setHeader ,該方法有兩個參數(shù),分別表示應(yīng)答頭的名字和值。和設(shè)置狀態(tài)代碼相似,設(shè)置應(yīng)答頭應(yīng)該在發(fā)送任何文檔內(nèi)容之前進行。

setDateHeader 方法和setIntHeadr 方法專門用來設(shè)置包含日期和整數(shù)值的應(yīng)答頭,前者避免了把Java 時間轉(zhuǎn)換為GMT 時間字符串的麻煩,后者則避免了把整數(shù)轉(zhuǎn)換為字符串的麻煩。

HttpServletResponse 還提供了許多設(shè)置

setContentType :設(shè)置Content-Type 頭。大多數(shù)Servlet 都要用到這個方法。 setContentLength :設(shè)置Content-Length 頭。對于支持持久HTTP 連接的瀏覽器來說,這個函數(shù)是很有用的。

addCookie :設(shè)置一個Cookie (Servlet API中沒有setCookie 方法,因為應(yīng)答往往包含多個Set-Cookie 頭)。

另外,如上節(jié)介紹,sendRedirect 方法設(shè)置狀態(tài)代碼302時也會設(shè)置Location 頭。

有關(guān)HTTP 頭詳細和完整的說明,請參見http://www.w3.org/Protocols/規(guī)范。

HTTP 應(yīng)答頭 說明

Allow 服務(wù)器支持哪些請求方法(如GET 、POST 等)。

Content-Encoding 文檔的編碼(Encode )方法。只有在解碼之后才可以得到Content-Type 頭指定的內(nèi)容類型。利用gzip 壓縮文檔能夠顯著地減少HTML 文檔的下載時間。Java 的GZIPOutputStream 可以很方便地進行g(shù)zip 壓縮,但只有Unix 上的Netscape 和Windows 上的IE 4、IE 5才支持它。因此,Servlet 應(yīng)該通過查看Accept-Encoding 頭(即

request.getHeader("Accept-Encoding"))檢查瀏覽器是否支持gzip ,為支持gzip 的瀏覽器返回經(jīng)gzip 壓縮的HTML 頁面,為其他瀏覽器返回普通頁面。

,

Content-Length 表示內(nèi)容長度。只有當瀏覽器使用持久HTTP 連接時才需要這個數(shù)據(jù)。如果你想要利用持久連接的優(yōu)勢,可以把輸出文檔寫入

ByteArrayOutputStram ,完成后查看其大小,然后把該值放入Content-Length 頭,最后通過byteArrayStream.writeTo(response.getOutputStream()發(fā)送內(nèi)容。

Content-Type 表示后面的文檔屬于什么MIME 類型。Servlet 默認為text/plain,但通常需要顯式地指定為text/html。由于經(jīng)常要設(shè)置Content-Type ,因此HttpServletResponse 提供了一個專用的方法setContentTyep 。

Date 當前的GMT 時間。你可以用setDateHeader 來設(shè)置這個頭以避免轉(zhuǎn)換時間格式的麻煩。

Expires 應(yīng)該在什么時候認為文檔已經(jīng)過期,從而不再緩存它?

Last-Modified 文檔的最后改動時間??蛻艨梢酝ㄟ^If-Modified-Since 請求頭提供一個日期,該請求將被視為一個條件GET ,只有改動時間遲于指定時間的文檔才會返回,否則返回一個304(Not Modified)狀態(tài)。Last-Modified 也可用setDateHeader 方法來設(shè)置。

Location 表示客戶應(yīng)當?shù)侥睦锶ヌ崛∥臋n。Location 通常不是直接設(shè)置的,而是通過HttpServletResponse 的sendRedirect 方法,該方法同時設(shè)置狀態(tài)代碼為302。

Refresh 表示瀏覽器應(yīng)該在多少時間之后刷新文檔,以秒計。除了刷新當前文檔之外,你還可以通過setHeader("Refresh", "5; URL=http://host/path") 讓瀏覽器讀取指定的頁面。注意這種功能通常是通過設(shè)置HTML 頁面HEAD 區(qū)的實現(xiàn),這是因為,自動刷新或重定向?qū)τ谀切┎荒苁褂肅GI 或Servlet 的HTML 編寫者十分重要。但是,對于Servlet 來說,直接設(shè)置Refresh 頭更加方便。注意Refresh 的意義是“N秒之后刷新本頁面或訪問指定頁面”,而不是“每隔N 秒刷新本頁面或訪問指定頁面”。因此,連續(xù)刷新要求每次都發(fā)送一個Refresh 頭,而發(fā)送204狀態(tài)代碼則可以阻止瀏覽器繼續(xù)刷新,不管是使用Refresh 頭還是。注意Refresh 頭不屬于HTTP 1.1正式規(guī)范的一部分,而是一個擴展,但Netscape 和IE 都支持它。

Server 服務(wù)器名字。Servlet 一般不設(shè)置這個值,而是由Web 服務(wù)器自己設(shè)置。

Set-Cookie 設(shè)置和頁面關(guān)聯(lián)的Cookie 。Servlet 不應(yīng)使用

response.setHeader("Set-Cookie", ...),而是應(yīng)使用HttpServletResponse 提供的專用方法addCookie 。參見下文有關(guān)Cookie 設(shè)置的討論。

WWW-Authenticate 客戶應(yīng)該在Authorization 頭中提供什么類型的授權(quán)信息?在包含401(Unauthorized )狀態(tài)行的應(yīng)答中這個頭是必需的。例如,

response.setHeader("WWW-Authenticate", "BASIC realm="executives"")。

,

注意Servlet 一般不進行這方面的處理,而是讓W(xué)eb 服務(wù)器的專門機制來控制受密碼保護頁面的訪問(例如.htaccess )。

標簽: