欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

HTTP緩存和瀏覽器的本地存儲

2021-02-05    分類: 網站建設

?一、HTTP緩存

http請求做為影響前端性能極為重要的一環(huán),因為請求受網絡影響很大,如果網絡很慢的情況下,頁面很可能會空白很久。對于首次進入網站的用戶可能要通過優(yōu)化接口性能和接口數(shù)量來解決。但是,對于重復進入頁面的用戶,除了瀏覽器緩存,http緩存可以很大程度對已經加載過的頁面進行優(yōu)化。

1.緩存位置

從緩存位置上來看,分為4種,從上往下依次檢查是否命中,如果但都沒有命中則重新發(fā)起請求。

Service Worker 是運行在瀏覽器背后的獨立線程,一般可以用來實現(xiàn)緩存功能。使用 Service Worker的話,傳輸協(xié)議必須為 HTTPS。

Memory Cache 也就是內存中的緩存,主要包含的是當前中頁面中已經抓取到的資源,例如頁面上已經下載的樣式、腳本、圖片等。讀取內存中的數(shù)據(jù)肯定比磁盤快,內存緩存雖然讀取高效,可是緩存持續(xù)性很短,會隨著進程的釋放而釋放。 一旦我們關閉 Tab 頁面,內存中的緩存也就被釋放了。

內存緩存中有一塊重要的緩存資源是preloader相關指令(例如)下載的資源。它可以一邊解析js/css文件,一邊網絡請求下一個資源。

Disk Cache 也就是存儲在硬盤中的緩存,讀取速度慢點,但是什么都能存儲到磁盤中,比之 Memory Cache 勝在容量和存儲時效性上。

絕大部分的緩存都來自Disk Cache,在HTTP 的協(xié)議頭中設置。

Push Cache(推送緩存)是 HTTP/2 中的內容,當以上三種緩存都沒有命中時,它才會被使用。它只在會話(Session)中存在,一旦會話結束就被釋放,并且緩存時間也很短暫,在Chrome瀏覽器中只有5分鐘左右,同時它也并非嚴格執(zhí)行HTTP頭中的緩存指令。

2.用戶操作對緩存的影響

下面主要說一下前端優(yōu)化能入手的地方,也就是強緩存和協(xié)商緩存,并且緩存策略都是通過設置 HTTP Header 來實現(xiàn)的。

3.強緩存

瀏覽器在第一次訪問接口后的response headers里會攜帶一些字段,這些字段決定關于這個請求的緩存情況,

與強緩存相關的header字段有兩個:

1、expires:過氣網紅,這是http1.0時的規(guī)范;它的值為一個絕對時間的GMT格式的時間字符串,如Mon, 10 Jun 2015 21:31:12 GMT,如果發(fā)送請求的時間在expires之前,那么本地緩存始終有效,否則就會發(fā)送請求到服務器來獲取資源

2、cache-control:新星:max-age=number,這是http1.1時出現(xiàn)的header信息,主要是利用該字段的max-age值來進行判斷,它是一個相對值;資源第一次的請求時間和Cache-Control設定的有效期,計算出一個資源過期時間,再拿這個過期時間跟當前的請求時間比較,如果請求時間在過期時間之前,就能命中緩存,否則就不行;

no-cache:不使用本地緩存。需要使用協(xié)商緩存,先與服務器確認返回的響應是否被更改,如果之前的響應中存在ETag,那么請求的時候會與服務端驗證,如果資源未被更改,則可以避免重新下載。

no-store:直接禁止游覽器緩存數(shù)據(jù),每次用戶請求該資源,都會向服務器發(fā)送一個請求,每次都會下載完整的資源。

public:可以被所有的用戶緩存,包括終端用戶和CDN等中間代理服務器。

private:只能被終端用戶的瀏覽器緩存,不允許CDN等中繼緩存服務器對其緩存。

注意:如果cache-control與expires同時存在的話,cache-control的優(yōu)先級高于expires

強緩存時段命中,會直接從緩存中返回數(shù)據(jù),返回值200;這一時間段,不管接口內容有沒有變化都不會進行請求更新。

4.協(xié)商緩存

當沒有強緩存時,會向服務端尋求幫助,也就是問一下服務端有沒有更改,向接口判斷是否有緩存。如果命中協(xié)商緩存則返回304狀態(tài)碼,并且從本地返回緩存內容。如果沒有命中,則重新發(fā)起請求。

協(xié)商緩存需要跟服務端通過特殊標示連接,即第一次請求的響應頭帶上某個字段(Last-Modified或者Etag),則后續(xù)請求則會帶上對應的請求字段(If-Modified-Since或者If-None-Match),若響應頭沒有Last-Modified或者Etag字段,則請求頭也不會有對應的字段。

具體過程如下:

Last-Modified/If-Modified-Since

1.瀏覽器第一次跟服務器請求一個資源,respone的header里加上Last-Modified:表示這個資源在服務器上的最后修改時間

2.瀏覽器再次跟服務器請求這個資源時,在request的header上加上If-Modified-Since的header:上一次請求時返回的Last-Modified的值

3.服務器再次收到資源請求時,會判斷最后修改時間是否有變化,如果沒有變化則返回304 Not Modified,但是不會返回資源內容;如果有變化,就正常返回資源內容,Last-Modified會被修改為最新的值。如果沒有變化,服務器返回304 Not Modified,Last-Modified不會修改,response header中不會再添加Last-Modified的header

4.瀏覽器收到304的響應后,就會從緩存中加載資源

Etag/If-None-Match

由服務器生成的每個資源的唯一標識字符串,只要資源有變化就這個值就會改變;其判斷過程與Last-Modified/If-Modified-Since類似,與Last-Modified不一樣的是,當服務器返回304 Not Modified的響應時,由于ETag重新生成過,response header中還會把這個ETag返回,即使這個ETag跟之前的沒有變化。

1.一些文件也許會周期性的更改,但是他的內容并不改變(僅僅改變的修改時間),這個時候我們并不希望客戶端認為這個文件被修改了,而重新GET;

2.某些文件修改非常頻繁,比如在秒以下的時間內進行修改,(比方說1s內修改了N次),If-Modified-Since能檢查到的粒度是s級的,這種修改無法判斷(或者說UNIX記錄MTIME只能精確到秒);

3.某些服務器不能精確的得到文件的最后修改時間。

Last-Modified與ETag是可以一起使用的,服務器會優(yōu)先驗證ETag,一致的情況下,才會繼續(xù)比對Last-Modified,最后才決定是否返回304。

二、瀏覽器本地存儲

瀏覽器本地緩存最常用的是cookie、localStroage、sessionStroage、webSql、indexDB。

1.cookie使用

cookie的用法很簡單,可以通過服務端設置,js也可以通過documnet.cookie="名稱=值;"(不要忘記以;分割)來設置。

cookie的值字符串可以用encodeURIComponent()來保證它不包含任何逗號、分號或空格(cookie值中禁止使用這些值).

cookie一般用做為登陸態(tài)保存、密碼、個人信息等關鍵信息保存使用,所以為了安全也是遵守同源策略原則的。

可以通過下面參數(shù)具體設置:

;path=path (例如 '/', '/mydir') 如果沒有定義,默認為當前文檔位置的路徑。

;domain=domain (例如 'example.com', 'subdomain.example.com') 如果沒有定義,默認為當前文檔位置的路徑的域名部分。與早期規(guī)范相反的是,在域名前面加 . 符將會被忽視,因為瀏覽器也許會拒絕設置這樣的cookie。如果指定了一個域,那么子域也包含在內。

;max-age=max-age-in-seconds (例如一年為606024*365)

;expires=date-in-GMTString-format 如果沒有定義,cookie會在對話結束時過期這個值的格式參見Date.toUTCString()

;secure (cookie只通過https協(xié)議傳輸)

;HttpOnly 限制web頁面程序的browser端script程序讀取cookie

缺點

容量有限制,不能超過4kb

在請求頭上帶著數(shù)據(jù)安全性差

2.localStorage和sessionStorage使用

html5新增本地存儲,localStorage生命周期是永久,除非主動清除localStorage信息,否則這些信息將永遠存在。存放數(shù)據(jù)大小為一般為5MB,sessionStorage僅在當前會話下有效,關閉頁面或瀏覽器后被清除。而且它僅在客戶端(即瀏覽器)中保存,不參與和服務器的通信。也是遵守同源策略原則的

  1. //?1、保存數(shù)據(jù)到本地?
  2. //?第一個參數(shù)是保存的變量名,第二個是賦給變量的值?
  3. localStorage.setItem('key',?'value');?
  4. //復雜類型儲存需要**利用JSON.stringify**將對象轉換成字符串;?
  5. //利用**JSON.parse**將字符串轉換成對象?
  6. //?2、從本地存儲獲取數(shù)據(jù)?
  7. localStorage.getItem('key');?
  8. //?3、從本地存儲刪除某個已保存的數(shù)據(jù)?
  9. localStorage.removeItem('key');?
  10. //?4、清除所有保存的數(shù)據(jù)?
  11. localStorage.clear();?

3. Web SQL

WebSQL是前端的一個獨立模塊,是web存儲方式的一種,我們調試的時候會經??吹?,只是一般很少使用。并且,當前只有谷歌支持,ie和火狐均不支持。

主要方法:

1.openDatabase:這個方法使用現(xiàn)有的數(shù)據(jù)庫或者新建的數(shù)據(jù)庫創(chuàng)建一個數(shù)據(jù)庫對象。

2.transaction:這個方法讓我們能夠控制一個事務,以及基于這種情況執(zhí)行提交或者回滾。

3.executeSql:這個方法用于執(zhí)行實際的 SQL 查詢。

4.indexDB

IndexedDB 就是瀏覽器提供的本地數(shù)據(jù)庫,它可以被網頁腳本創(chuàng)建和操作。IndexedDB 允許儲存大量數(shù)據(jù),提供查找接口,還能建立索引。這些都是 LocalStorage 所不具備的。就數(shù)據(jù)庫類型而言,IndexedDB 不屬于關系型數(shù)據(jù)庫(不支持 SQL 查詢語句),更接近 NoSQL 數(shù)據(jù)庫。

分享名稱:HTTP緩存和瀏覽器的本地存儲
當前鏈接:http://aaarwkj.com/news/99227.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供移動網站建設、Google、響應式網站、網站導航、關鍵詞優(yōu)化靜態(tài)網站

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

商城網站建設
欧美香蕉在线观看视频| 91中文字幕在线一区| 亚洲精品小视频在线观看| 国产91黑丝视频在线观看| 国产高清在线不卡一区| 日韩中文字幕乱码一区| 日韩欧美亚洲另类视频| 久久久久亚洲av成人| 99热只有这里才有精品| 久久亚洲国产成人精品性色| 中日韩中文字幕一区二区| 日本欧美一区二区三区高清| 亚洲av欧美日韩国产| 亚洲天堂av日韩在线| 超薄丝袜美腿一二三区在线播放| 2021最新四虎永久免费| 中国女人内射91熟女| 丝袜啪啪啪麻豆白虎内射| 日韩国产一区二区在线观看| 精品av一区二区在线| 偷怕自拍在线免费观看| 亚洲国产香蕉视频在线播放| 麻豆成人久久精品二区三| 一级黄片国产精品久久| 麻豆国产原创av色哟哟| 日本人妻伦理在线播放| 亚洲av乱码久久精品蜜桃| 欧美三级视频一区二区三区| 日本av东京热在线播放| 国产精彩在线视频成人在线| 校园春色亚洲欧美日韩| 女子张开腿让男人捅爽| 人妻系列少妇人妻偷人| 午夜欧美激情在线视频| 香蕉夜夜草草久久亚洲香蕉| 91午夜福利视频鉴赏| 人妻有码av中文字幕久久| 91久久福利国产成人精品| 午夜在线精品福利视频| 日韩爱爱特级视频中文字幕| 久久日韩一区二区三区|