日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長提供免費收錄網(wǎng)站服務,提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

利用nginx設置瀏覽器協(xié)商緩存

 

強緩存與協(xié)商緩存的區(qū)別

強緩存:瀏覽器不與服務端協(xié)商直接取瀏覽器緩存

協(xié)商緩存:瀏覽器會先向服務器確認資源的有效性后才決定是從緩存中取資源還是重新獲取資源


協(xié)商緩存運作原理

現(xiàn)在有一個這樣的業(yè)務情景:后端的靜態(tài)資源會不定時地發(fā)生更新,而因為瀏覽器默認使用強緩存,會默認從瀏覽器緩存中取到過時的資源。

現(xiàn)在我們希望瀏覽器每次獲取資源的時候都向后端確認資源是否更新,就要設置瀏覽器使用協(xié)商緩存

那么后端如何判斷資源是否更新了呢?這時就要用到Etag和Last-Modified兩項響應頭。

每次收到一個靜態(tài)資源的請求時,后端都將資源的最后修改時間(Last-Modified)、根據(jù)資源內(nèi)容計算出來的Etag放在響應頭給前端。

前端收到響應后將這兩項緩存起來,然后在下次請求同樣資源的時候,將這兩項的內(nèi)容放到If-Modified-Since和If-None-Match這兩項請求頭中。

服務端收到這兩項后,會與資源當前生成的Etag和Last-Modified做比較,如果兩者都一致,說明資源沒有更新,服務端會返回304空響應;否則,說明資源有更新,服務端會將完整的資源內(nèi)容返回


實現(xiàn)

那么如何實現(xiàn)這樣一個復雜的過程呢?其實很簡單,只要使用Nginx作為靜態(tài)資源的服務器,再在響應頭加上Cache-Control:no-cache就可以了。

下面來分步驟實現(xiàn)一下

1. 使用nginx作為靜態(tài)資源的服務器

在nginx的配置中,將對靜態(tài)資源的請求映射到資源的磁盤路徑上

 1 http {
 2 server {
 3 listen 80;
 4 ...
 5 location /picture/ {
 6 alias D:/luozixi/tcp_test/picture/;
 7 # alias是重定義路徑
 8 # 比如訪問127.0.0.1/picture/1_new.gif,則會映射為訪問D:/luozixi/tcp_test/picture/1_new.gif
 9 # web應用根本不會收到請求,picture的請求都被nginx處理了
10 # alias是替換,root是拼接
11 autoindex on;
12 # 訪問127.0.0.1/picture/,會得到目錄的索引界面
13 }
14 }
15 } 

2. 重新加載nginx配置

nginx -s reload

3. 此時,請求靜態(tài)資源的時候nginx會自動在response頭中加上Etag和Last-Modified兩項

利用nginx設置瀏覽器協(xié)商緩存

 

4. 但是這時發(fā)現(xiàn),如果不配置Cache-Contrl: no-cache,瀏覽器在下次請求這個資源的時候不會將請求發(fā)向后端,而是直接從緩存中獲取資源

5. 在nginx中配置

location /picture/ { 
 add_header Cache-Control no-cache;
 alias D:/luozixi/tcp_test/picture/; 
} 

6. 清除瀏覽器緩存后第一次發(fā)起請求,會得到一個正常的200 Response,而且響應頭里已經(jīng)有了Cache-Control: no-cache,表示使用協(xié)商緩存

7. 再次發(fā)起請求后,會發(fā)現(xiàn)請求頭已經(jīng)帶上了If-Modified-Since和If-None-Match兩項

利用nginx設置瀏覽器協(xié)商緩存

 

8.%20服務端(nginx)收到這兩項后,會與資源當前生成的Etag和Last-Modified做比較,如果兩者都一致,說明資源沒有更新,服務端會返回304空響應;否則,說明資源有更新,服務端會將完整的資源內(nèi)容返回

另外,服務器驗證If-Modified-Since的方式只是簡單的字符串比較,即使資源的Last-Modified比If-Modified-Since要早,服務端仍認為資源有更新

9.%20瀏覽器在收到304響應后,會從瀏覽器緩存中取資源。因此速度非常塊

 


no-cache與no-store的區(qū)別

no-cache表示不緩存過期資源,緩存會向服務器進行有效處理確認之后處理資源

而no-store才是真正的不進行緩存。

分享到:
標簽:緩存 協(xié)商 瀏覽器
用戶無頭像

網(wǎng)友整理

注冊時間:

網(wǎng)站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨大挑戰(zhàn)2018-06-03

數(shù)獨一種數(shù)學游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數(shù)有氧達人2018-06-03

記錄運動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定