Cache-control

Cache-control

Cache-Control 是最重要的規則。這個欄位用於指定所有快取機制在整個請求/回響鏈中必須服從的指令。這些指令指定用於阻止快取對請求或回響造成不利干擾的行為。這些指令通常覆蓋默認快取算法。快取指令是單向的,即請求中存在一個指令並不意味著回響中將存在同一個指令。

網頁的快取是由HTTP訊息頭中的“Cache-Control”來控制的,常見的取值有private、no-cache、max-age、must-revalidate等,默認為private。其作用根據不同的重新瀏覽方式分為以下幾種情況。

基本介紹

  • 中文名:快取控制
  • 外文名:Cache-Control
  • 用於:指定所有快取機制
  • 覆蓋:默認快取算法
  • 定義:Cache-Control
  • 控制:Cache-Control網頁的快取
瀏覽步驟
適用的值
表1展示了適用的值。
表 1. 常用 Cache-Control 值
Cache-directive說明
public
所有內容都將被快取(客戶端和代理伺服器都可快取)
private
內容只快取到私有快取中(僅客戶端可以快取,代理伺服器不可快取)
no-cache
必須先與伺服器確認返回的回響是否被更改,然後才能使用該回響來滿足後續對同一個網址的請求。因此,如果存在合適的驗證令牌 (ETag),no-cache 會發起往返通信來驗證快取的回響,如果資源未被更改,可以避免下載。
no-store
所有內容都不會被快取到快取或 Internet 臨時檔案中
must-revalidation/proxy-revalidation
如果快取的內容失效,請求必須傳送到伺服器/代理以進行重新驗證
max-age=xxx (xxx is numeric)
快取的內容將在 xxx 秒後失效, 這個選項只在HTTP 1.1可用, 並如果和Last-Modified一起使用時, 優先權較高
不同的情形下的瀏覽器回響
表 2 表明在不同的情形下,瀏覽器是將請求重新傳送到伺服器還是使用快取的內容。
表 2. 對 Cache-Control 值的瀏覽器回響
Cache-directive打開一個新的瀏覽器視窗在原視窗中單擊 Enter 按鈕刷新單擊 Back 按鈕
public
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
瀏覽器重新傳送請求到伺服器
瀏覽器呈現來自快取的頁面
private
瀏覽器重新傳送請求到伺服器
第一次,瀏覽器重新傳送請求到伺服器;此後,瀏覽器呈現來自快取的頁面
瀏覽器重新傳送請求到伺服器
瀏覽器呈現來自快取的頁面
no-cache/no-store
瀏覽器重新傳送請求到伺服器
瀏覽器重新傳送請求到伺服器
瀏覽器重新傳送請求到伺服器
瀏覽器重新傳送請求到伺服器
must-revalidation/proxy-revalidation
瀏覽器重新傳送請求到伺服器
第一次,瀏覽器重新傳送請求到伺服器;此後,瀏覽器呈現來自快取的頁面
瀏覽器重新傳送請求到伺服器
瀏覽器呈現來自快取的頁面
max-age=xxx (xxx is numeric)
在 xxx 秒後,瀏覽器重新傳送請求到伺服器
在 xxx 秒後,瀏覽器重新傳送請求到伺服器
瀏覽器重新傳送請求到伺服器
在 xxx 秒後,瀏覽器重新傳送請求到伺服器
Cache-Control是關於瀏覽器快取的最重要的設定,因為它覆蓋其他設定,比如 Expires 和 Last-Modified。另外,由於瀏覽器的行為基本相同,這個屬性是處理跨瀏覽器快取問題的最有效的方法。
失效
Expires 頭部欄位提供一個日期和時間,回響在該日期和時間後被認為失效。失效的快取條目通常不會被快取(無論是代理快取還是用戶代理快取)返回,除非首先通過原始伺服器(或者擁有該實體的最新副本的中介快取)驗證。(注意:cache-control max-age 和 s-maxage 將覆蓋 Expires 頭部。)
Expires 欄位接收以下格式的值:“Expires: Sun, 08 Nov 2009 03:37:26 GMT”。如果查看內容時的日期在給定的日期之前,則認為該內容沒有失效並從快取中提取出來。反之,則認為該內容失效,快取將採取一些措施。
不同操作下不同瀏覽器的回響
表 3-6 表明針對不同用戶操作的不同瀏覽器的行為。
表 3. 當用戶打開一個新的瀏覽器視窗時的失效操作
Firefox 3.5IE 8Chrome 3Safari 4
內容沒有失效
瀏覽器呈現來自快取的頁面
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
內容失效
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
表 4. 當用戶在原始瀏覽器視窗中單擊 Enter 按鈕時的失效操作
Firefox 3.5IE 8Chrome 3Safari 4
內容沒有失效
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
瀏覽器重新傳送請求到伺服器。返回代碼是 304
瀏覽器重新傳送請求到伺服器。返回代碼是 304
內容失效
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器呈現來自快取的頁面
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
表 5. 當用戶按 F5 鍵刷新頁面時的失效操作
Firefox 3.5IE 8Chrome 3Safari 4
內容沒有失效
瀏覽器重新傳送請求到伺服器。返回代碼是 304
瀏覽器重新傳送請求到伺服器。返回代碼是 304
瀏覽器重新傳送請求到伺服器。返回代碼是 304
瀏覽器重新傳送請求到伺服器。返回代碼是 304
內容失效
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
表 6. 當用戶單擊 Back 或 Forward 按鈕時的失效操作
Firefox 3.5IE 8Chrome 3Safari 4
內容沒有失效
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
內容失效
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
瀏覽器重新傳送請求到伺服器。返回代碼是 200
注意:所有瀏覽器都假定為使用默認設定運行。
Last-Modified/E-Tag
Last-Modified 實體頭部欄位值通常用作一個快取驗證器。簡單來說,如果實體值在 Last-Modified 值之後沒有被更改,則認為該快取條目有效。ETag 回響頭部欄位值是一個實體標記,它提供一個 “不透明” 的快取驗證器。這可能在以下幾種情況下提供更可靠的驗證:不方便存儲修改日期;HTTP 日期值的 one-second 解決方案不夠用;或者原始伺服器希望避免由於使用修改日期而導致的某些衝突。
不同的瀏覽器有不同的配置行為。
表 7-10 表明針對不同用戶操作的不同瀏覽器的行為。
表 7. 當用戶打開一個新的瀏覽器視窗時的 Last-Modified E-Tag 操作
Firefox 3.5IE 8Chrome 3Safari 4
內容自上次訪問以來沒有被修改
瀏覽器重新傳送請求到伺服器。返回代碼是 304
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 304
瀏覽器重新傳送請求到伺服器。返回代碼是 304
內容自上次訪問以來已經被修改
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
表 8. 當用戶在原始瀏覽器視窗中單擊 Enter 按鈕時的 Last-Modified E-Tag 操作
Firefox 3.5IE 8Chrome 3Safari 4
內容自上次訪問以來沒有被修改
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
瀏覽器重新傳送請求到伺服器。返回代碼是 304
瀏覽器重新傳送請求到伺服器。返回代碼是 304
內容自上次訪問以來已經被修改
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器呈現來自快取的頁面
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
表 9. 當用戶按 F5 鍵刷新頁面時的 Last-Modified E-Tag 操作
Firefox 3.5IE 8Chrome 3Safari 4
內容自上次訪問以來沒有被修改
瀏覽器重新傳送請求到伺服器。返回代碼是 304
瀏覽器重新傳送請求到伺服器。返回代碼是 304
瀏覽器重新傳送請求到伺服器。返回代碼是 304
瀏覽器重新傳送請求到伺服器。返回代碼是 304
內容自上次訪問以來已經被修改
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
表 10. 沒有快取設定且用戶單擊 Back 或 Forward 按鈕
Firefox 3.5IE 8Chrome 3Safari 4
內容自上次訪問以來沒有被修改
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
內容自上次訪問以來已經被修改
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
瀏覽器呈現來自快取的頁面
瀏覽器重新傳送請求到伺服器。返回代碼是 200
注意:所有瀏覽器都假定使用默認設定運行。
不進行任何快取相關設定
如果您不定義任何快取相關設定,則不同的瀏覽器有不同的行為。有時,同一個瀏覽器在相同的情形下每次運行時的行為都是不同的。情況可能很複雜。另外,有些不該快取的內容如果被快取,將會導致安全問題。
不同的瀏覽器有不同的行為。
表 11 展示了不同的瀏覽器行為。
表 11. 沒有快取設定且用戶打開一個新的瀏覽器視窗
Firefox 3.5IE 8Chrome 3Safari 4
打開一個新頁面
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
在原始視窗中單擊 Enter 按鈕
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器呈現來自快取的頁面。
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
按 F5 鍵刷新
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
單擊 Back 或 Forward 按鈕
瀏覽器呈現來自快取的頁面。
瀏覽器呈現來自快取的頁面。
瀏覽器重新傳送請求到伺服器。返回代碼是 200
瀏覽器重新傳送請求到伺服器。返回代碼是 200
注意:所有瀏覽器都假定使用默認設定運行。
關鍵結論
最後, 概括下關鍵的結論:
關鍵結論
打開新視窗
如果指定cache-control的值為private、no-cache、must-revalidate,那么打開新視窗訪問時都會重新訪問伺服器。而如果指定了max-age值,那么在此值內的時間裡就不會重新訪問伺服器,例如:Cache-control: max-age=5 表示當訪問此網頁後的5秒內不會去再次訪問伺服器.
在地址欄回車
如果值為private或must-revalidate,則只有第一次訪問時會訪問伺服器,以後就不再訪問。如果值為no-cache,那么每次都會訪問。如果值為max-age,則在過期之前不會重複訪問。
按後退按扭
如果值為private、must-revalidate、max-age,則不會重訪問,而如果為no-cache,則每次都重複訪問.
按刷新按扭
無論為何值,都會重複訪問.

相關詞條

熱門詞條

聯絡我們