一、基礎概念
Last-Modified是HTTP的一個頭部信息,指示一個被請求資源(如HTML、CSS、JavaScript等)的最後修改時間。它表示的是UTC時間的日期和時間字元串,以RFC 7231規範中的日期時間格式來呈現。例如:
Last-Modified: Wed, 18 Nov 2020 16:14:31 GMT
當客戶端請求某個資源時,會將上次請求該資源時得到的Last-Modified值通過If-Modified-Since請求頭部發送回伺服器。如果該資源在此時間後沒有被修改過,伺服器會返回HTTP 304「Not Modified」狀態碼,否則返回200狀態碼和新的資源內容。
另外需要注意的是,如果伺服器無法獲取被請求資源的最後修改時間,或者該資源被修改的時間不可知,則該頭部信息的值應設為一個固定的時間標記(如「0000-01-01T00:00:00Z」)。同時,當一個資源被創建時,也可以通過設置Last-Modified值為創建時間來表示該資源暫時為最新版本。
二、緩存策略優化
利用Last-Modified頭部信息可以實現緩存策略的優化。在第一次請求某個資源時,伺服器會返回資源的Last-Modified值,並在響應頭部加入Cache-Control、Expires等緩存相關的頭部信息,告知客戶端應該緩存該資源的有效期限。當下一次請求該資源時,客戶端會發送If-Modified-Since請求頭部信息以告知伺服器緩存情況,如果伺服器返回304狀態碼,表示客戶端的緩存仍然是最新的,並且該資源的有效期限還未到期,則客戶端不需要再次請求該資源,因為緩存中的版本已經是最新的了。
同時,伺服器也可以結合Etag頭部信息來進一步細化緩存策略,當資源被改動後,伺服器會更改資源的Etag值,並在下次請求時一併返回,如果客戶端的Etag值與服務端的不一致,則表示緩存已失效,需要重新獲取最新的資源。
三、服務端支持和使用注意事項
為了使伺服器支持Last-Modified頭部信息,需要在服務端編寫相應的代碼邏輯以在響應頭部中加入Last-Modified頭部信息,並處理客戶端的If-Modified-Since請求頭部信息。以下是一個簡單的例子:
import ( "net/http" "time" ) func handler(w http.ResponseWriter, r *http.Request) { // 設置Last-Modified信息 modTime := time.Date(2020, time.November, 18, 16, 14, 31, 0, time.UTC) w.Header().Set("Last-Modified", modTime.UTC().Format(http.TimeFormat)) // 處理If-Modified-Since信息 if modHeader := r.Header.Get("If-Modified-Since"); modHeader != "" { modSince, err := time.Parse(http.TimeFormat, modHeader) if err == nil && !modTime.After(modSince) { w.WriteHeader(http.StatusNotModified) return } } // 返回資源內容 http.ServeFile(w, r, "path/to/resource") }
需要注意的是,由於Last-Modified值是按UTC時間計算的,因此在響應頭部中必須將時間轉換為UTC格式。同時,如果伺服器無法獲取被請求資源的修改時間,可以忽略掉If-Modified-Since請求頭的判斷,直接返回最新的版本即可。
四、總結
Last-Modified頭部信息是HTTP協議中用於表示資源修改時間的一種標準方式,可以實現緩存、更新等優化策略,提升HTTP的性能和可靠性。在實際開發中,我們需要充分理解其原理,合理應用其優點,並注意一些問題和注意事項,以確保系統的正確性和可靠性。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/270836.html