了解Header的作用,先了解下 header中都有什么? 如下圖所示

1、Accept,瀏覽器端能夠處理的內(nèi)容類型。
例如: Accept: text/html 代表請(qǐng)求端可以接受服務(wù)器回發(fā)的類型為 text/html 也就是我們常說的html文檔。如果服務(wù)器無(wú)法返回text/html類型的數(shù)據(jù),服務(wù)器應(yīng)該返回一個(gè)406錯(cuò)誤(non acceptable)。通配符 * 代表任意類型,例如 Accept: / 代表瀏覽器可以處理所有類型,(一般瀏覽器發(fā)給服務(wù)器都是發(fā)這個(gè))。
2、Accept-Encoding, 請(qǐng)求端能夠處理的的壓縮編碼。通常指定壓縮方法,是否支持壓縮,支持什么壓縮方法(gzip,deflate),(注意:這不是指字符編碼)。
3、Accept-Language, 瀏覽器當(dāng)前設(shè)置的語(yǔ)言。
語(yǔ)言跟字符集的區(qū)別:中文是語(yǔ)言,中文有多種字符集,比如BIG5,GB2312,GBK等等;例如: 'Accept-Language: en-us'
4、Connection:瀏覽器與服務(wù)器的連接類型
Connection: keep-alive 當(dāng)一個(gè)網(wǎng)頁(yè)打開完成后,客戶端和服務(wù)器之間用于傳輸HTTP數(shù)據(jù)的TCP連接不會(huì)關(guān)閉,如果客戶端再次訪問這個(gè)服務(wù)器上的網(wǎng)頁(yè),會(huì)繼續(xù)使用這一條已經(jīng)建立的連接。
Connection: close 代表一個(gè)Request完成后,客戶端和服務(wù)器之間用于傳輸HTTP數(shù)據(jù)的TCP連接會(huì)關(guān)閉。 當(dāng)客戶端再次發(fā)送Request,需要重新建立TCP連接。
5、Host,發(fā)送請(qǐng)求的頁(yè)面的域名。(發(fā)送請(qǐng)求時(shí),該報(bào)頭域是必需的),請(qǐng)求報(bào)頭域主要用于指定被請(qǐng)求資源的Internet主機(jī)和端口號(hào),它通常從HTTP URL中提取出來的。
例如: 我們?cè)跒g覽器中輸入:http://www.hzau.edu.cn,瀏覽器發(fā)送的請(qǐng)求消息中,就會(huì)包含Host請(qǐng)求報(bào)頭域,如下:
Host:www.hzau.edu.cn,此處使用缺省端口號(hào)80,若指定了端口號(hào),則變成:Host:指定端口號(hào)。
6、Referer,發(fā)送請(qǐng)求的頁(yè)面的URI。當(dāng)瀏覽器向web服務(wù)器發(fā)送請(qǐng)求的時(shí)候,一般會(huì)帶上Referer,告訴服務(wù)器我是從哪個(gè)頁(yè)面鏈接過來的,服務(wù)器借此可以獲得一些信息用于處理。
比如從我主頁(yè)上鏈接到一個(gè)朋友那里,他的服務(wù)器就能夠從HTTP Referer中統(tǒng)計(jì)出每天有多少用戶點(diǎn)擊我主頁(yè)上的鏈接訪問他的網(wǎng)站。
7、User-Agent,瀏覽器的用戶代理字符串。告訴HTTP服務(wù)器, 客戶端使用的操作系統(tǒng)和瀏覽器的名稱和版本。
我們上網(wǎng)登陸論壇的時(shí)候,往往會(huì)看到一些歡迎信息,其中列出了你的操作系統(tǒng)的名稱和版本,你所使用的瀏覽器的名稱和版本,這往往讓很多人感到很神奇,實(shí)際上,服務(wù)器應(yīng)用程序就是從User-Agent這個(gè)請(qǐng)求報(bào)頭域中獲取到這些信息User-Agent請(qǐng)求報(bào)頭域允許客戶端將它的操作系統(tǒng)、瀏覽器和其它屬性告訴服務(wù)器。
例如: User-Agent: Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 5.1; Trident/4.0; CIBA;
.NET CLR 2.0.50727; .NET CLR 3.0.4506.2152; .NET CLR 3.5.30729; .NET4.0C; InfoPath.2; .NET4.0E)
8、Cookie,用來存儲(chǔ)一些用戶信息以便讓服務(wù)器辨別用戶身份的(大多數(shù)需要登錄的網(wǎng)站上面會(huì)比較常見)。
比如cookie會(huì)存儲(chǔ)一些用戶的用戶名和密碼,當(dāng)用戶登錄后就會(huì)在客戶端產(chǎn)生一個(gè)cookie來存儲(chǔ)相關(guān)信息,這樣瀏覽器通過讀取cookie的信息去服務(wù)器上驗(yàn)證并通過后會(huì)判定你是合法用戶,從而允許查看相應(yīng)網(wǎng)頁(yè)。當(dāng)然cookie里面的數(shù)據(jù)不僅僅是上述范圍,還有很多信息可以存儲(chǔ)是cookie里面,比如sessionid等。
9、Cache-Control,指明當(dāng)前資源的有效期,控制瀏覽器是否直接從瀏覽器緩存取數(shù)據(jù),還是重新發(fā)請(qǐng)求到服務(wù)器獲取數(shù)據(jù)。
我們網(wǎng)頁(yè)的緩存控制是由HTTP頭中的“Cache-control”來實(shí)現(xiàn)的,常見值有private、no-cache、max-age、must-revalidate等,默認(rèn)為private。這幾種值的作用是根據(jù)重新查看某一頁(yè)面時(shí)不同的方式來區(qū)分的:
(1)、打開新窗口
值為private、no-cache、must-revalidate,那么打開新窗口訪問時(shí)都會(huì)重新訪問服務(wù)器。而如果指定了max-age值(單位為秒),那么在此值內(nèi)的時(shí)間里就不會(huì)重新訪問服務(wù)器,例如:
Cache-control: max-age=5(表示當(dāng)訪問此網(wǎng)頁(yè)后的5秒內(nèi)再次訪問不會(huì)去服務(wù)器)
(2)、在地址欄回車
值為private或must-revalidate則只有第一次訪問時(shí)會(huì)訪問服務(wù)器,以后就不再訪問。
值為no-cache,那么每次都會(huì)訪問。
值為max-age,則在過期之前不會(huì)重復(fù)訪問。
(3)、按后退按扭
值為private、must-revalidate、max-age,則不會(huì)重訪問,
值為no-cache,則每次都重復(fù)訪問
(4)、按刷新按扭
無(wú)論為何值,都會(huì)重復(fù)訪問
10、If-Modified-Since, 把瀏覽器端緩存頁(yè)面的最后修改時(shí)間發(fā)送到服務(wù)器去,服務(wù)器會(huì)把這個(gè)時(shí)間與服務(wù)器上實(shí)際文件的最后修改時(shí)間進(jìn)行對(duì)比。
如果時(shí)間一致,那么返回304,客戶端就直接使用本地緩存文件。如果時(shí)間不一致,就會(huì)返回200和新的文件內(nèi)容??蛻舳私拥街?,會(huì)丟棄舊文件,把新文件緩存起來,并顯示在瀏覽器中。
例如:Mon, 17 Aug 2015 12:03:33 GMT