欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2019年12月17日 10:18:43   作者:luozx207  
這篇文章主要介紹了基于nginx設(shè)置瀏覽器協(xié)商緩存過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

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

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

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

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

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

  現(xiàn)在有一個(gè)這樣的業(yè)務(wù)情景:后端的靜態(tài)資源會(huì)不定時(shí)地發(fā)生更新,而因?yàn)闉g覽器默認(rèn)使用強(qiáng)緩存,會(huì)默認(rèn)從瀏覽器緩存中取到過(guò)時(shí)的資源。

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

  那么后端如何判斷資源是否更新了呢?這時(shí)就要用到Etag和Last-Modified兩項(xiàng)響應(yīng)頭。

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

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

  服務(wù)端收到這兩項(xiàng)后,會(huì)與資源當(dāng)前生成的Etag和Last-Modified做比較,如果兩者都一致,說(shuō)明資源沒(méi)有更新,服務(wù)端會(huì)返回304空響應(yīng);否則,說(shuō)明資源有更新,服務(wù)端會(huì)將完整的資源內(nèi)容返回

實(shí)現(xiàn)

  那么如何實(shí)現(xiàn)這樣一個(gè)復(fù)雜的過(guò)程呢?其實(shí)很簡(jiǎn)單,只要使用nginx作為靜態(tài)資源的服務(wù)器,再在響應(yīng)頭加上Cache-Control:no-cache就可以了。

  下面來(lái)分步驟實(shí)現(xiàn)一下

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

    在nginx的配置中,將對(duì)靜態(tài)資源的請(qǐng)求映射到資源的磁盤(pán)路徑上

http {
  server {
  listen 80;
  ...
  location /picture/ {
    alias D:/luozixi/tcp_test/picture/;
    # alias是重定義路徑
    # 比如訪問(wèn)127.0.0.1/picture/1_new.gif,則會(huì)映射為訪問(wèn)D:/luozixi/tcp_test/picture/1_new.gif
    # web應(yīng)用根本不會(huì)收到請(qǐng)求,picture的請(qǐng)求都被nginx處理了
    # alias是替換,root是拼接
    autoindex on;
    # 訪問(wèn)127.0.0.1/picture/,會(huì)得到目錄的索引界面
    }
  }
}

  2. 重新加載nginx配置

nginx -s reload

  3. 此時(shí),請(qǐng)求靜態(tài)資源的時(shí)候nginx會(huì)自動(dòng)在response頭中加上Etag和Last-Modified兩項(xiàng)

  

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

  5. 在nginx中配置

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

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

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

  

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

    另外,服務(wù)器驗(yàn)證If-Modified-Since的方式只是簡(jiǎn)單的字符串比較,即使資源的Last-Modified比If-Modified-Since要早,服務(wù)端仍認(rèn)為資源有更新

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

  

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

  no-cache表示不緩存過(guò)期資源,緩存會(huì)向服務(wù)器進(jìn)行有效處理確認(rèn)之后處理資源

  而no-store才是真正的不進(jìn)行緩存。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用Nginx和pm2部署Next.js項(xiàng)目

    使用Nginx和pm2部署Next.js項(xiàng)目

    本文主要介紹了使用Nginx和pm2部署Next.js項(xiàng)目,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Nginx部署vue項(xiàng)目和配置代理的問(wèn)題解析

    Nginx部署vue項(xiàng)目和配置代理的問(wèn)題解析

    這篇文章主要介紹了Nginx部署vue項(xiàng)目和配置代理,需本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,要的朋友可以參考下
    2021-08-08
  • Nginx配置Basic Auth登錄認(rèn)證的實(shí)現(xiàn)方法

    Nginx配置Basic Auth登錄認(rèn)證的實(shí)現(xiàn)方法

    這篇文章主要介紹了Nginx配置Basic Auth登錄認(rèn)證的實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • Nginx禁止ip訪問(wèn)或非法域名訪問(wèn)

    Nginx禁止ip訪問(wèn)或非法域名訪問(wèn)

    這篇文章主要介紹了Nginx禁止ip訪問(wèn)或非法域名訪問(wèn),需要的朋友可以參考下
    2022-04-04
  • Nginx解決403 forbidden的完整步驟

    Nginx解決403 forbidden的完整步驟

    這篇文章主要給大家介紹了關(guān)于Nginx解決403 forbidden的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • nginx cookie有效期討論小結(jié)

    nginx cookie有效期討論小結(jié)

    這篇文章主要介紹了nginx cookie有效期討論小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • nginx開(kāi)啟ws訪問(wèn)和4層負(fù)載的編譯參數(shù)示例

    nginx開(kāi)啟ws訪問(wèn)和4層負(fù)載的編譯參數(shù)示例

    這篇文章主要為大家介紹了nginx開(kāi)啟ws訪問(wèn)和4層負(fù)載的編譯參數(shù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • 使用?nginx?搭建代理服務(wù)器(正向代理?https?網(wǎng)站)的詳細(xì)步驟

    使用?nginx?搭建代理服務(wù)器(正向代理?https?網(wǎng)站)的詳細(xì)步驟

    這篇文章主要介紹了使用?nginx?搭建代理服務(wù)器(正向代理?https?網(wǎng)站)指南的相關(guān)操作,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-08-08
  • Nginx進(jìn)程管理和重載原理詳解

    Nginx進(jìn)程管理和重載原理詳解

    這篇文章主要給大家介紹了關(guān)于Nginx進(jìn)程管理和重載原理的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 詳解Nginx服務(wù)器中配置全站HTTPS安全連接的方法

    詳解Nginx服務(wù)器中配置全站HTTPS安全連接的方法

    這篇文章主要介紹了詳解Nginx服務(wù)器中配置全站HTTPS安全連接的方法,其中要點(diǎn)還是在于SSL證書(shū)的申請(qǐng),需要的朋友可以參考下
    2016-01-01

最新評(píng)論