摘要:和前端相關(guān)的緩存一般都是指緩存,也就是瀏覽器緩存。緩存機制緩存一般分為強制緩存和協(xié)商緩存,接下來將分別介紹一下這兩個緩存機制。這兩種緩存機制可以同時存在,不過強制緩存的優(yōu)先級高于協(xié)商緩存。
瀏覽器緩存 基礎(chǔ)概念
緩存無處不在,有客戶端緩存,服務端緩存,代理服務器緩存等等。和前端相關(guān)的緩存一般都是指http緩存,也就是瀏覽器緩存。
就是說ajax請求之后,會把請求的url和返回的響應結(jié)果保存在緩存中,當下一次調(diào)用ajax發(fā)送相同的請求時,瀏覽器會從緩存中把數(shù)據(jù)取出來,這是為了提高頁面的響應速度和用戶體驗,什么時候會出現(xiàn)這個現(xiàn)象呢,就是要這兩次的請求url和請求參數(shù)完全一樣的時候,瀏覽器就不會與服務器交互。
緩存的優(yōu)缺點 優(yōu)點現(xiàn)在說一下緩存的好處,好處顯而易見嘛,就是說請求一些靜態(tài)資源,js,css,圖片這些,不會變化的資源,請求會變得更快,加快了客戶端加載網(wǎng)頁的速度,提高了頁面的響應速度,也減少了冗余數(shù)據(jù)的傳遞,節(jié)省了網(wǎng)絡(luò)帶寬流量,減少服務端的負擔,大大提高了網(wǎng)站性能。
缺點但是缺點也顯而易見,客戶端和服務端交互的時候,服務端的數(shù)據(jù)雖然變了,但是頁面緩存沒有改變,對于相同的url,ajax提交過去以后,瀏覽器是從緩存中拿數(shù)據(jù),這種情況肯定是不被允許的。
那么什么時候會觸發(fā)緩存呢,在這之前先說一下緩存機制吧。
緩存機制緩存一般分為強制緩存和協(xié)商緩存,接下來將分別介紹一下這兩個緩存機制。
強制緩存就是緩存中已經(jīng)有了請求數(shù)據(jù)的時候,客戶端直接從緩存中獲取數(shù)據(jù),只有當緩存中沒有請求數(shù)據(jù)的時候,客戶端才會從服務端拿取數(shù)據(jù)。
協(xié)商緩存也成為對比緩存,就是說客戶端會從緩存中獲取到一個緩存數(shù)據(jù)的標識,根據(jù)這個標識會請求服務端驗證是否失效,如果沒有失效,服務端會返回304,這時候客戶端就直接從緩存中取數(shù)據(jù),如果失效了,服務端會返回新的數(shù)據(jù)。
這兩種緩存機制可以同時存在,不過強制緩存的優(yōu)先級高于協(xié)商緩存。
現(xiàn)在我們簡單的了解了一下緩存機制的原理,該說一下什么時候會觸發(fā)緩存,服務端是如何判斷緩存是否失效呢?大家都知道,發(fā)送請求的時候會有請求數(shù)據(jù)和響應數(shù)據(jù),這個被稱為報文,報文中包含首部header和主體部分body。與緩存相關(guān)的規(guī)則信息就包含在header中。body中的內(nèi)容就是http請求真正要傳輸?shù)臄?shù)據(jù)。舉個http報文的頭部例子
現(xiàn)在我們對報文中出現(xiàn)的與緩存有關(guān)的信息分析一下
強制緩存服務器響應的header中會用兩個字段來表明,Expires和Cache-Control。
ExpiresExpires的值是服務端返回的數(shù)據(jù)到期時間。當再次請求時的請求時間小于返回的此時間,則直接使用緩存數(shù)據(jù),但是因為客戶端和服務端的時間可能有誤差,所以這個緩存命中可能會有誤差,另一方面,expires是http1.0的產(chǎn)物,所以現(xiàn)在大多數(shù)都使用Cache-Control
Cache-ControlCache-Control有很多產(chǎn)物,不同的屬性代表的意義不同。
private: 客戶端可以緩存
public: 客戶端和服務器可以緩存
max-age=t:緩存內(nèi)容在t秒后失效
no-cache:需要使用協(xié)商緩存來驗證緩存數(shù)據(jù)
no-store:所有內(nèi)容不使用緩存
協(xié)商緩存協(xié)商緩存需要判斷是否可以用緩存,瀏覽器第一次請求數(shù)據(jù)的時候,服務器會將緩存標識與數(shù)據(jù)一起響應給客戶端,客戶端將他們備份到緩存中,再次請求時,客戶端會將緩存中的標識發(fā)送給服務器,服務器根據(jù)此標識判斷是否失效,如果沒有失效,服務端返回304狀態(tài)碼,瀏覽器拿到此狀態(tài)嗎就可以直接使用緩存數(shù)據(jù)了。對于協(xié)商緩存來說,緩存標識很重要,對于理解協(xié)商緩存,這是重點。
接下來介紹一下協(xié)商緩存的緩存方案
Last-Modified Last-Modified服務端在響應請求時,會返回資源的最后修改時間
If-Modified-Since客戶端再次請求服務端的時候,請求頭會包含這個字段,后面跟著在緩存中獲取的資源的最后修改時間。服務端收到請求發(fā)現(xiàn)此請求頭中有If-Modified-Since字段,會與被請求資源的最后修改時間進行對比,如果一致則會返回304和響應報文頭,瀏覽器從緩存中獲取數(shù)據(jù)即可。從字面上看,就是說從某個時間節(jié)點開始看,是否被修改了,如果被修改了,就返回整個數(shù)據(jù)和200 OK,如果沒有被修改,服務端只要返回響應頭報文,304 Not Modified.
If-Unmodified-Since和If-Modified-Since相反,就是說從某個時間點開始看,是否沒有被修改.如果沒有被修改,就返回整個數(shù)據(jù)和200 OK,如果被修改了,不傳輸和返回412 Precondition failed (預處理錯誤)
If-Modified-Since和If-Unmodified-Since區(qū)別就是一個是修改了返回數(shù)據(jù)一個是沒修改返回數(shù)據(jù)。
Last-Modified也有缺點,就是說服務端的資源只是改了下修改時間,但是其實里面的內(nèi)容并沒有改變,會因為Last-Modified發(fā)生了改變而返回整個數(shù)據(jù),為了解決這個問題,http1.1推出了Etag
Etag Etag服務端響應請求時,通過此字段告訴客戶端當前資源在服務端生成的唯一標識(生成規(guī)則由服務端決定)
If-None-Match再次請求服務端的時候,客戶端的請求報文頭部會包含此字段,后面的值是從緩存中獲取的標識,服務端接收到報文后發(fā)現(xiàn)If-None-Match則與被請求的資源的唯一標識對比。如果相同,說明資源不用修改,則響應header,客戶端直接從緩存中獲取數(shù)據(jù),返回狀態(tài)碼304,如果不同,說明資源被改過,返回整個數(shù)據(jù),200 OK。
但是實際應用中由于Etag的計算是使用算法計算出來的,而算法會占用服務端的資源,所有服務端的資源都是寶貴的,所以很少使用Etag。
現(xiàn)在順便說一下不同的刷新的請求執(zhí)行過程哈
瀏覽器直接輸入url,回車
瀏覽器發(fā)現(xiàn)緩存中有這個文件了,不用繼續(xù)請求了,直接去緩存中拿(最快)
F5
告訴瀏覽器,去服務端看下文件是否過期了,于是瀏覽器發(fā)了一個請求帶上If-Modified-Since
Ctrl+F5
告訴瀏覽器,先把緩存刪了,再去服務端請求完整的資源文件過來,于是瀏覽器就完成了強制更新的操作
如果不想使用緩存怎么辦呢,接下來說一下解決方法
解決方法在ajax發(fā)送請求前加上 xmlHttpRequest.setRequestHeader(“Cache-Control”,”no-cache”);
在服務端加 header(“Cache-Control: no-cache, must-revalidate”);
在ajax發(fā)送請求前加上 xmlHttpRequest.setRequestHeader(“If-Modified-Since”,”0″);
在 Ajax 的 URL 參數(shù)后加上 "?fresh=" + Math.random(); //當然這里參數(shù) fresh 可以任意取了
第五種方法和第四種類似,在 URL 參數(shù)后加上 "?timestamp=" + new Date().getTime();
用POST替代GET:不推薦
jQuery提供一個防止ajax使用緩存的方法:
修改load 加載的url地址,如在url 多加個時間參數(shù)就可以:
function loadEventInfoPage(eventId){ $.ajaxSetup ({ cache: true // AJAX cache 下面加上時間后load的頁面中的js、css圖片等都會重新加載, //加上這句action會重新加載,但是js、css、圖片等會走緩存 }); $("#showEventInfo").load(ctx + "/custEvents/viewEvent.action", {"complaint.Id":eventId, "tt":(new Date()).getTime()},function(){}) }
9.設(shè)置html的緩存
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/61907.html
摘要:根據(jù)標準,到目前為止,一共有種緩存機制,有些是之前已有,有些是才新加入的。首次請求緩存有效期內(nèi)請求緩存過期后請求一般瀏覽器會將緩存記錄及緩存文件存在本地文件夾中。 騰訊 Bugly 特約作者:賀輝超 1. H5 緩存機制介紹 H5,即 HTML5,是新一代的 HTML 標準,加入很多新的特性。離線存儲(也可稱為緩存機制)是其中一個非常重要的特性。H5 引入的離線存儲,這意味著 web ...
摘要:啟動性能瓶頸分析與解決方案翻譯自的,從屬于筆者的前端入門與工程實踐。我們必須要清醒地認識到全面評測以挖掘出真正性能瓶頸的重要性。這可能是最佳的方式了,類似于這樣的模式鼓勵基于路由的分組,目前被與廣泛使用。 JavaScript 啟動性能瓶頸分析與解決方案 翻譯自 Addy Osmani 的 JavaScript Start-up Performance,從屬于筆者的Web 前端入門與工...
摘要:要想讓模塊再次運行,必須清除緩存。用戶自己編寫的模塊,稱為文件模塊。并且和指向了同一個模塊對象。模塊路徑這是在定位文件模塊的具體文件時指定的查找策略,具體表現(xiàn)為一個路徑組成的數(shù)組。 前言 Node應用是由模塊組成的,Node遵循了CommonJS的模塊規(guī)范,來隔離每個模塊的作用域,使每個模塊在它自身的命名空間中執(zhí)行。 CommonJS規(guī)范的主要內(nèi)容: 模塊必須通過 module.exp...
閱讀 2171·2023-04-25 20:45
閱讀 1085·2021-09-22 15:13
閱讀 3652·2021-09-04 16:48
閱讀 2588·2019-08-30 15:53
閱讀 939·2019-08-30 15:44
閱讀 956·2019-08-30 15:43
閱讀 1013·2019-08-29 16:33
閱讀 3442·2019-08-29 13:08