搜尋
首頁運維Nginxnginx expires控制頁面快取的方法

nginx expires控制頁面快取的方法

May 12, 2023 am 08:04 AM
nginxexpires

語法:expires [time|epoch|max|pff]預設值:offexpires指令控制http應答中的「expires」和「cache-control」header頭部訊息,啟動控制頁面快取的作用time:可以使用正數或負數。 “expires”頭標的值將透過目前系統時間加上設定time值來設定。 time值也控制"cache-control"的值:負數表示no-cache正數或零表示max-age=time epoch:指定「expires」的值為1january,1970,00:00:01 gmtmax:指定「expires 」的值為31december2037 23:59:59gmt,"cache-control"的值為10年。 -1:指定「expires」的值為目前伺服器時間-1s,即永遠過期。 off:不修改「expires」和"cache-control"的值
expires使用了特定的時間,並且要求伺服器和客戶端的是中嚴格同步。
而cache-control是用max-age指令指定元件被緩存多久。
對於不支援http1.1的瀏覽器,還是需要expires來控制。所以最好能指定兩個響應頭。但http規範規定max-age指令將重寫expires頭。

如果不想讓代理程式或瀏覽器緩存,加上no-cache參數或private參數:
# expires 1d;
add_header cache-control no-cache;
add_header cache-control private ;
這樣瀏覽器f5刷新時,回傳的依然是200,而不是304.

記錄一個nginx控制快取的範例:
       expires 1d;
      add_ expires 1d;
      add_er-ache-trold cache;
       add_header cache-control private;
       if (!-e $request_filename) {
    #   add_header cache-control no-cache;
  #   add_header cache-control private;
當我將add_header寫在rewrite之後時,發現add_header竟然不起作用了。 。是因為寫進了if裡面..


apache的mod_expires模組使得在使用expires頭時能像max-age那樣以相對的方式設定日期,透過expiresdefault指令完成。例如:圖片等過期時間為請求開始的10年後

expiresdefault "access plus 10years"
filematch>
它像回應中發送expires頭和cache-control max-age頭。

expires|etag控制頁面快取區別expires:像上面文章提到的:expires指令控制http應答中的「expires」和「cache-control」header頭部訊息,啟動控制頁面快取的作用time :可以使用正數或負數。 “expires”頭標的值將透過目前系統時間加上設定time值來設定。 time值也控制"cache-control"的值:負數表示no-cache正數或零表示max-age=time epoch:指定「expires」的值為1january,1970,00:00:01 gmtmax:指定「expires 」的值為31december203723:59:59gmt,"cache-control"的值為10年。 -1:指定「expires」的值為目前伺服器時間-1s,即永遠過期。 off:不修改「expires」和"cache-control"的值

expires使用了特定的時間,並且要求伺服器和客戶端的是中嚴格同步。
而cache-control是用max-age指令指定元件被緩存多久。
對於不支援http1.1的瀏覽器,還是需要expires來控制。所以最好能指定兩個響應頭。但http規範規定max-age指令將重寫expires頭。一般用於頁面變化不是很快的時候,如果快取過期了,瀏覽器在重用它之前會首先確認他是否有效,就是一個“條件get請求”,如果有效,返回304狀態碼。 expires透過last-modified響應頭來決定。如圖:
第一次造訪:
請求:
nginx expires控制页面缓存的方法

返回:
nginx expires控制页面缓存的方法

第二次存取:
請求:
nginx expires控制页面缓存的方法

返回:
nginx expires控制页面缓存的方法

這時回傳的狀態碼是304,而在請求中比第一次多了if-modified -since頭,和原始伺服器中的last-modified製作比較,所以實現瀏覽器快取並判斷是否過期。
簡單的說,last-modified 與if-modified-since 都是用來記錄頁面最後修改時間的http 頭訊息,只是last-modified 是由伺服器傳送到客戶端的http 頭,而if-modified-since則是由客戶端向伺服器發送的頭,可以看到,再次要求本地存在的cache 頁面時,客戶端會透過if-modified-since頭將先前伺服器端發過來的last-modified最後修改時間戳發送回去,這是為了讓伺服器端進行驗證,透過這個時間戳判斷客戶端的頁面是否是最新的,如果不是最新的,則傳回新的內容,如果是最新的,則傳回304告訴客戶端其本機cache的頁面是最新的,於是客戶端就可以直接從本地加載頁面了,這樣在網路上傳輸的資料就會大大減少,同時也減輕了伺服器的負擔。

如果不想讓代理程式或瀏覽器緩存,加上no-cache參數或private參數:
# expires 1d;
add_header cache-control no-cache;
add_header cache-control private ;
nginx expires控制页面缓存的方法



etag:實體標籤,是用來確認網頁伺服器和瀏覽器快取有效性的一種機制。原始伺服器使用etag回應頭來指定元件的etag瀏覽器透過if-none-match頭將etag傳回原始伺服器。如果匹配,返回304
如圖:
第一次訪問:
請求:
nginx expires控制页面缓存的方法

返回:
nginx expires控制页面缓存的方法


nginx expires控制页面缓存的方法


nginx expires控制页面缓存的方法





#########第二次請求:############返回:############仍傳回的狀態碼是304,而在請求中比第一次多了if -none-match頭。所以實現瀏覽器快取。如果這個值對不上,則快取過期。 ###etags和if-none-match是一種常用的判斷資源是否改變的方法。類似last-modified和http-if-modified-since。但有所不同的是last-modified和http-if-modified-since只判斷資源的最後修改時間,而etags和if-none-match可以是資源任何的任何屬性。 ###etags和if-none-match的工作原理是在httpresponse中加入etags資訊。當客戶端再次請求該資源時,將在httprequest中加入if-none-match資訊(etags的值)。如果伺服器驗證資源的etags沒有改變(該資源沒有改變),將傳回一個304狀態;否則,伺服器將傳回200狀態,並傳回該資源和新的etags。 ###iis上的etag格式需要修改。 ######

以上是nginx expires控制頁面快取的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:亿速云。如有侵權,請聯絡admin@php.cn刪除
nginx行動:示例和現實應用程序nginx行動:示例和現實應用程序Apr 17, 2025 am 12:18 AM

NGINX可用於提升網站性能、安全性和可擴展性。 1)作為反向代理和負載均衡器,NGINX可優化後端服務和分擔流量。 2)通過事件驅動和異步架構,NGINX高效處理高並發連接。 3)配置文件允許靈活定義規則,如靜態文件服務和負載均衡。 4)優化建議包括啟用Gzip壓縮、使用緩存和調整worker進程。

NGINX單元:支持不同的編程語言NGINX單元:支持不同的編程語言Apr 16, 2025 am 12:15 AM

NGINXUnit支持多種編程語言,通過模塊化設計實現。 1.加載語言模塊:根據配置文件加載相應模塊。 2.應用啟動:調用語言運行時執行應用代碼。 3.請求處理:將請求轉發給應用實例。 4.響應返回:將處理後的響應返回給客戶端。

在Nginx和Apache之間進行選擇:適合您的需求在Nginx和Apache之間進行選擇:適合您的需求Apr 15, 2025 am 12:04 AM

NGINX和Apache各有優劣,適合不同場景。 1.NGINX適合高並發和低資源消耗場景。 2.Apache適合需要復雜配置和豐富模塊的場景。通過比較它們的核心特性、性能差異和最佳實踐,可以幫助你選擇最適合需求的服務器軟件。

nginx怎麼啟動nginx怎麼啟動Apr 14, 2025 pm 01:06 PM

問題:如何啟動 Nginx?答案:安裝 Nginx啟動 Nginx驗證 Nginx 是否已啟動探索其他啟動選項自動啟動 Nginx

怎麼查看nginx是否啟動怎麼查看nginx是否啟動Apr 14, 2025 pm 01:03 PM

確認 Nginx 是否啟動的方法:1. 使用命令行:systemctl status nginx(Linux/Unix)、netstat -ano | findstr 80(Windows);2. 檢查端口 80 是否開放;3. 查看系統日誌中 Nginx 啟動消息;4. 使用第三方工具,如 Nagios、Zabbix、Icinga。

nginx怎麼關閉nginx怎麼關閉Apr 14, 2025 pm 01:00 PM

要關閉 Nginx 服務,請按以下步驟操作:確定安裝類型:Red Hat/CentOS(systemctl status nginx)或 Debian/Ubuntu(service nginx status)停止服務:Red Hat/CentOS(systemctl stop nginx)或 Debian/Ubuntu(service nginx stop)禁用自動啟動(可選):Red Hat/CentOS(systemctl disable nginx)或 Debian/Ubuntu(syst

nginx在windows中怎麼配置nginx在windows中怎麼配置Apr 14, 2025 pm 12:57 PM

如何在 Windows 中配置 Nginx?安裝 Nginx 並創建虛擬主機配置。修改主配置文件並包含虛擬主機配置。啟動或重新加載 Nginx。測試配置並查看網站。選擇性啟用 SSL 並配置 SSL 證書。選擇性設置防火牆允許 80 和 443 端口流量。

nginx403錯誤怎麼解決nginx403錯誤怎麼解決Apr 14, 2025 pm 12:54 PM

服務器無權訪問所請求的資源,導致 nginx 403 錯誤。解決方法包括:檢查文件權限。檢查 .htaccess 配置。檢查 nginx 配置。配置 SELinux 權限。檢查防火牆規則。排除其他原因,如瀏覽器問題、服務器故障或其他可能的錯誤。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中