摘要:服務(wù)器通過這兩個首部字段告知客戶端資源的緩存過期時間和緩存最大生命周期??蛻舳说弥Y源的緩存過期時間和最大生命周期后,即可自行判斷是否可不建立與服務(wù)器的鏈接,直接從瀏覽器緩存中獲取資源。
瀏覽器緩存
瀏覽器緩存分為強緩存和協(xié)商緩存
強緩存
客戶端第一次問服務(wù)器要某個資源時,服務(wù)器丟還給客戶端所請求的這個資源的同時,告訴客戶端將這個資源保存在本地,并且在未來的某個時點之前如果還需要這個資源,直接從本地獲取就可以,不用向服務(wù)器請求,這種方式緩存下來的資源稱為強緩存。
強緩存利用http的返回頭部中的Expires(實體首部字段)或者Cache-Control(通用首部字段)兩個字段來控制,用來表示資源的緩存時間。
服務(wù)器通過這兩個首部字段告知客戶端資源的緩存過期時間和緩存最大生命周期。
客戶端得知資源的緩存過期時間和最大生命周期后,即可自行判斷是否可不建立與服務(wù)器的鏈接,直接從瀏覽器緩存中獲取資源。
注:命中強緩存時,瀏覽器同樣會收到status=200的respones,chrome中可通過size區(qū)分從服務(wù)器返回的資源還是強緩存獲得的資源。
(1). Expires(http1.0的規(guī)范)
其值為一個絕對時間的GMT格式的時間字符串,代表緩存資源的過期時間,在該時點之前,即為命中緩存。 缺點:服務(wù)器返回的Expires時點是服務(wù)器上的時間,可能與客戶端有時間差,時間差太大可能造成緩存混亂
(2). Cache-Control:max-age(http1.1的規(guī)范)
強緩存利用其max-age值來判斷資源緩存的最大生命周期,它的值單位為秒。Cache-Control:max-age=3600代表資源有效時間為1小時,即從第一次獲取該資源起一小時內(nèi)的請求都被認為可命中強緩存。 注:Cache-Control描述的是相對時間,采用本地時間來計算資源的有效期,所以相比Expires更可靠 這兩個Header可以只用其一,也可以一起使用。一起使用時以Cache-Control為準(zhǔn)
協(xié)商緩存
客戶端第一次問服務(wù)器要某個資源時,服務(wù)器丟給客戶端所請求的這個資源的同時,將該資源的一些信息(文件摘要、或最后修改時間)也返回給客戶端,告訴客戶端將這個資源緩存在本地。當(dāng)客戶端下一次需要這個資源時,將請求以及相關(guān)信息(文件摘要、或者最后修改時間)一并發(fā)送給服務(wù)器,由服務(wù)器來判斷客戶端緩存的資源是否需要更新:如不需要更新,就直接告訴客戶端獲取本地緩存資源;如需要更新,則將最新的資源連同相應(yīng)的信息一并返回給客戶端。
當(dāng)強緩存未命中時,瀏覽器就會發(fā)送請求到服務(wù)器,服務(wù)器會驗證協(xié)商緩存是否命中,如果協(xié)商緩存命中,請求返回的http狀態(tài)為304,并會顯示說明Not Modified,瀏覽器收到該返回后,就會從緩存中加載了。
協(xié)商緩存利用[Last-Modified , If-Modified-Since] 和 [ETag , If-None-Match]這兩對Header來管理。
(1). Last-Modified & If-Modified-Since
Last-Modified為實體首部字段,值為資源最后更新時間,隨服務(wù)器response返回。 If-Modified-Since為請求首部字段,通過比較兩個時間來判斷資源在兩次請求期間是否有過修改,如果沒有修改,則命中協(xié)商緩存,瀏覽器從緩存中獲取資源;如果有過修改,則服務(wù)器返回資源,同時返回新的Last-Modified時間
(2). ETag & If-None-Match
ETag為相應(yīng)頭部字段,表示資源內(nèi)容的唯一標(biāo)識,隨服務(wù)器response返回 If-None-Match為請求頭部字段,服務(wù)器通過比較請求頭部的If-None-Match與當(dāng)前資源的ETag是否一致來判斷資源是否在兩次請求之間有過修改,如果沒有修改,則命中協(xié)商緩存,瀏覽器從緩存中獲取資源;如果有過修改,則服務(wù)器返回資源,同時返回新的ETag 協(xié)商緩存管理: [Last-Modified , If-Modified-Since]和[ETag , If-None-Match]一般同時啟用,這是為了處理Last-Modified不可靠的情況。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/51604.html
摘要:瀏覽器緩存只存在于每個單獨的客戶端,因此它是私有緩存。表示該資源既能被瀏覽器緩存,也能被任何中間人比如代理服務(wù)器等緩存。普通刷新會啟用協(xié)商緩存,忽略強緩存。只有在地址欄或收藏夾輸入網(wǎng)址通過鏈接引用資源等情況下,瀏覽器才會啟用強緩存。 前言 在訪問一個網(wǎng)頁時,客戶端會從服務(wù)器下載所需的資源。但是有些資源很少發(fā)生變動,例如 HTML、JS、CSS、圖片、字體文件等。如果每次加載頁面都從源服...
摘要:接下來的內(nèi)容中我們將通過緩存位置緩存策略以及實際場景應(yīng)用緩存策略來探討瀏覽器緩存機制。是運行在瀏覽器背后的獨立線程,一般可以用來實現(xiàn)緩存功能。在所有瀏覽器緩存中,覆蓋面基本是最大的。 一、前言 緩存可以說是性能優(yōu)化中簡單高效的一種優(yōu)化方式了。一個優(yōu)秀的緩存策略可以縮短網(wǎng)頁請求資源的距離,減少延遲,并且由于緩存文件可以重復(fù)利用,還可以減少帶寬,降低網(wǎng)絡(luò)負荷。對于一個數(shù)據(jù)請求來說,可以分為...
摘要:接下來的內(nèi)容中我們將通過緩存位置緩存策略以及實際場景應(yīng)用緩存策略來探討瀏覽器緩存機制。是運行在瀏覽器背后的獨立線程,一般可以用來實現(xiàn)緩存功能。在所有瀏覽器緩存中,覆蓋面基本是最大的。 一、前言 緩存可以說是性能優(yōu)化中簡單高效的一種優(yōu)化方式了。一個優(yōu)秀的緩存策略可以縮短網(wǎng)頁請求資源的距離,減少延遲,并且由于緩存文件可以重復(fù)利用,還可以減少帶寬,降低網(wǎng)絡(luò)負荷。 對于一個數(shù)據(jù)請求來說,可以分...
摘要:接下來的內(nèi)容中我們將通過緩存位置緩存策略以及實際場景應(yīng)用緩存策略來探討瀏覽器緩存機制。是運行在瀏覽器背后的獨立線程,一般可以用來實現(xiàn)緩存功能。在所有瀏覽器緩存中,覆蓋面基本是最大的。 一、前言 緩存可以說是性能優(yōu)化中簡單高效的一種優(yōu)化方式了。一個優(yōu)秀的緩存策略可以縮短網(wǎng)頁請求資源的距離,減少延遲,并且由于緩存文件可以重復(fù)利用,還可以減少帶寬,降低網(wǎng)絡(luò)負荷。 對于一個數(shù)據(jù)請求來說,可以分...
摘要:接下來的內(nèi)容中我們將通過緩存位置緩存策略以及實際場景應(yīng)用緩存策略來探討瀏覽器緩存機制。是運行在瀏覽器背后的獨立線程,一般可以用來實現(xiàn)緩存功能。在所有瀏覽器緩存中,覆蓋面基本是最大的。 一、前言 緩存可以說是性能優(yōu)化中簡單高效的一種優(yōu)化方式了。一個優(yōu)秀的緩存策略可以縮短網(wǎng)頁請求資源的距離,減少延遲,并且由于緩存文件可以重復(fù)利用,還可以減少帶寬,降低網(wǎng)絡(luò)負荷。 對于一個數(shù)據(jù)請求來說,可以分...
閱讀 3550·2021-11-22 15:22
閱讀 3338·2019-08-30 15:54
閱讀 2732·2019-08-30 15:53
閱讀 823·2019-08-29 11:22
閱讀 3543·2019-08-29 11:14
閱讀 2084·2019-08-26 13:46
閱讀 2219·2019-08-26 13:24
閱讀 2283·2019-08-26 12:22