網頁的緩衝是由 HTTP訊息頭中的“Cache-control”來控制的,常見的取值有private 、no-cache、max-age、must- revalidate等,預設為private。其作用根據不同的重新瀏覽方式分為 以下幾種情況:
(1) 開啟新視窗
值為private、no-cache、must-revalidate,那麼開啟新窗 口訪問時都會重新訪問伺服器。
而如果指定了max-age值,那麼在此值內的時間裡就不會重新訪問 伺服器,例如:
Cache-control: max-age=5(表示當訪問此網頁後的5秒內再次訪問不會去伺服器)
(2) 在地址欄斷行符號
值為private或must-revalidate則只有第一次訪問時會訪問伺服器,以後 就不再訪問。
值為no-cache,那麼每次都會訪問。
值為max-age,則在到期之前不會重複訪問。
(3) 按後退按扭
值為private、must-revalidate、max-age,則不會重訪問,
值為no- cache,則每次都重複訪問
(4) 按重新整理按扭
無論為何值,都會重複訪問
Cache-control值為 “no-cache”時,訪問此頁面不會在Internet臨時文章夾留下頁面備份。
另外,通過指 定“Expires”值也會影響到緩衝。例如,指定Expires值為一個早已過去的時間,那麼訪 問此網時若重複在地址欄按斷行符號,那麼每次都會重複訪問: Expires: Fri, 31 Dec 1999 16:00:00 GMT
比如:禁止頁面在IE中緩衝
HTTP響應訊息頭部設定:
CacheControl = no- cache
Pragma=no-cache
Expires = -1
Expires是個好東東,如果伺服器上的網頁經常變化, 就把它設定為-1,表示立即到期。如果一個網頁每天淩晨1點更新,可以把Expires設定為第二天的淩 晨1點。
當HTTP1.1伺服器指定 CacheControl = no-cache時,瀏覽器就不會緩衝該網頁。
舊式 HTTP 1.0 伺服器不能使用 Cache-Control 標題。
所以為了向後相容 HTTP 1.0 伺服器,IE使用 Pragma:no-cache 標題對 HTTP 提供特殊支援。
如果用戶端通過安全連線 (https://)/ 與伺服器 通訊,且伺服器在響應中返回 Pragma:no-cache 標題,
則 Internet Explorer不會緩衝此響應。 注意:Pragma:no-cache 僅當在安全連線中使用時才防止緩衝,如果在非安全頁中使用,處理方式與 Expires:-1相同,該頁將被緩衝,但被標記為立即到期
header常用指令
header分為三部分:
第一部分為HTTP協議的版本(HTTP-Version);
第二部分為狀態碼(Status);