首先咱們從資源被請求時,請求行爲和資源緩存的不一樣來看下HTTP頭信息的表現:瀏覽器
資源的首次請求: 緩存
頁面刷新-資源緩存未過時: 服務器
頁面刷新-資源緩存已過時-資源未變動: url
頁面刷新-資源緩存已過時-資源已變動: 3d
資源被再次請求時-緩存未過時: 代理
當瀏覽器請求資源文件時,默認會將源資文件緩存到本地以便重複使用,加快網頁的加載速度。code
from disk cache
和 from memory cache
兩類。當首次訪問網頁時,資源文件被緩存在內存中,同時也會在本地磁盤中保留一份副本。當用戶刷新頁面,若是緩存的資源沒有過時,那麼直接從內存中讀取並加載。當用戶關閉頁面後,當前頁面緩存在內存中的資源被清空。當用戶再一次訪問頁面時,若是資源文件的緩存沒有過時,那麼將從本地磁盤進行加載並再次緩存到內存之中。服務器能夠經過Response Headers使用 expires
和 cache-control
設置一個有效的過時時間,當瀏覽器再次請求資源時會判斷本地緩存是否已過時:cdn
這是HTTP1.0版本的產物,屬於 Response Headers,使用一個UTC格式的日期時間字符串表示資源的過時時間。blog
使用 expires
設置的過時時間是以服務器時間爲準的,它可能跟瀏覽器時間不一致,不一樣時區也會存在影響。內存
這是HTTP1.1版本的產物,屬於 Response Headers,提供更多詳細的緩存策略,能夠根據三種不一樣性質經過逗號進行組合使用:
cache-control: no-store/no-cache/must-revalidate
;cache-control:public/private
;cache-control: max-age/s-maxage
;是否不使用緩存:
must-revalidate
: 當本地的資源緩存沒有過時前,使用本地緩存;當本地資源緩存已過時時,須要進行緩存檢測(默認值)。no-cache
: 無論本地的資源緩存是否過時,都須要進行緩存檢測。no-store
: 禁止瀏覽器緩存資源,每次請求資源都去服務器從新下載。是否爲私有緩存:
public
: 公共緩存,表示瀏覽器和代理服務器均可以設置緩存(默認值)。private
: 私有緩存,僅瀏覽器設置緩存。設置過時時間:
max-age
:使用 cache-control: max-age=60
的形式表示本地緩存的資源將在xx秒以後過時,單位爲秒,會覆蓋 Expires
的設置。s-maxage
: 使用方式同 max-age
,在public設置下有效,針對共享緩存(代理服務器)有效。使用 max-age
的優勢在於設置的過時時間是一個相對於瀏覽器的時間,不受服務器和瀏覽器時間不一致的影響,也不會由於時區的不一樣而受到影響。
當資源文件的 Response Headers 中帶有 last-modified 字段,可是卻缺乏 expires
和 cache-control
用來表示資源緩存的過時時間的字段,這個時候瀏覽器會使用啓發式緩存來確認該資源緩存的過時時間:
瀏覽器會根據 date
和 last-modified
之間的時間差值的10%來做爲資源緩存的過時時間。
當瀏覽器從新向服務器請求資源時,若是原先的 Response Headers 中存在 last-modified
或者 etag
信息,那麼在 Request Headers 中會經過 if-modified-since
和 if-none-match
將以前的信息帶給服務器進行檢測。若是服務器資源相對於本地的資源緩存沒有發生變動,那麼將會返回304狀態碼,表示資源未更新,讓瀏覽器使用本地的資源緩存,這就是 協商緩存。
若是原先的 Response Headers 中沒有 last-modified
和 etag
信息,那麼將從服務器從新下載資源文件。
這兩個字段都是HTTP1.0版本的產物。
last-modified
: 屬於 Response Headers,表示資源最後一次修改的時間。
if-modified-since
: 屬於 Request Headers,用來判斷服務器端資源是否在該傳遞的時間以後作了修改,若是沒有修改那麼服務器將返回304狀態碼,讓瀏覽器使用資源緩存。
這是HTTP1.1版本的產物。
etag
: 屬於 Response Headers,表示資源的惟一標識符,由服務器端生成。
if-none-match
: 屬於 Request Headers,用來判斷服務器資源是否與該傳遞的標識符不一致,若是一致則表示資源文件沒有修改過,服務器將返回304狀態碼,讓瀏覽器使用資源緩存。會覆蓋 if-modified-since
的設置。
使用etag來判斷服務器端資源文件是否作了修改,主要有如下考慮:
last-modified
只能精確到秒,而有些服務器資源可能在1秒內進行了屢次修改。瀏覽器的緩存策略還跟用戶的行爲有關: