一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術(shù)及軟件下載分享
分類導航

云服務器|WEB服務器|FTP服務器|郵件服務器|虛擬主機|服務器安全|DNS服務器|服務器知識|Nginx|IIS|Tomcat|

服務器之家 - 服務器技術(shù) - Nginx - 基于nginx設(shè)置瀏覽器協(xié)商緩存過程詳解

基于nginx設(shè)置瀏覽器協(xié)商緩存過程詳解

2020-03-13 16:01luozx207 Nginx

這篇文章主要介紹了基于nginx設(shè)置瀏覽器協(xié)商緩存過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

這篇文章主要介紹了基于nginx設(shè)置瀏覽器協(xié)商緩存過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

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

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

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

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

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

  現(xiàn)在我們希望瀏覽器每次獲取資源的時候都向后端確認資源是否更新,就要設(shè)置瀏覽器使用協(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
2
3
4
5
6
7
8
9
10
11
12
13
14
15
http {
  server {
  listen 80;
  ...
  location /picture/ {
    alias D:/luozixi/tcp_test/picture/;
    # alias是重定義路徑
    # 比如訪問127.0.0.1/picture/1_new.gif,則會映射為訪問D:/luozixi/tcp_test/picture/1_new.gif
    # web應用根本不會收到請求,picture的請求都被nginx處理了
    # alias是替換,root是拼接
    autoindex on;
    # 訪問127.0.0.1/picture/,會得到目錄的索引界面
    }
  }
}

  2. 重新加載nginx配置

?
1
nginx -s reload

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

  基于nginx設(shè)置瀏覽器協(xié)商緩存過程詳解

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

  5. 在nginx中配置

?
1
2
3
4
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設(shè)置瀏覽器協(xié)商緩存過程詳解

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

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

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

  基于nginx設(shè)置瀏覽器協(xié)商緩存過程詳解

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

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

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

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://www.cnblogs.com/luozx207/p/11058348.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: a看片 | 香港三级系列在线播放 | 成人私人影院在线观看网址 | 日韩精品成人免费观看 | 午夜理论电影在线观看亚洲 | 男人搡女人视频免费看 | 亚洲欧美日韩精品久久亚洲区 | 99精品久久99久久久久久 | 国产精品视频网 | 无遮免费网站在线入口 | 性鸥美| 亚色九九九全国免费视频 | 欧美一区二区三区成人看不卡 | 青草视频在线观看免费网站 | 欧美日韩精彩视频 | 精品人人视屏 | 日韩高清在线免费看 | 人人做人人爽人人爱 | 久久人妻无码毛片A片麻豆 久久热这里只有 精品 | 国产偷啪 | 日日免费视频 | a级片在线观看免费 | 国产女乱淫真高清免费视频 | 免费亚洲成人 | 国产3p在线| 久久精品99国产精品日本 | japanesexxxx日本妞| 黑人女性猛交xxxxxⅹxx | 色图大全 | 日本美女视频韩国视频网站免费 | 天天做天天爱天天一爽一毛片 | 给我视频免费看 | 母性本能在线观看 | 亚洲视频在线一区二区三区 | 99精品影院 | 成人福利在线播放 | 亚洲午夜精品久久久久久人妖 | 男人的天堂视频在线 | 农村妇女野战bbxxx | tk白丝丨vk| 日韩色图区|