在老的版本的MVC裏面,有一種能夠緩存視圖的特性(OutputCache),能夠保持同一個參數的請求,在N段時間內,直接從mvc的緩存中讀取,不去走視圖的邏輯。html
//老版本的.NET 作法
[OutputCache(Duration =20)]//設置過時時間爲20秒
public ActionResult ExampleCacheAction()
{
var time=DateTime.Now.ToString("yyyy年MM月dd日 HH時mm分ss秒");
ViewBag.time= time;
return View();
}
在Asp.Net core 2.1中,官方文檔上稱:響應緩存可減小客戶端或代理對 web 服務器的請求數。 響應緩存還可減小量工做的 web 服務器執行程序生成響應。 響應緩存由標頭,指定你但願客戶端、 代理和緩存響應的中間件如何控制。git
在Asp.Net Core 2.1 中,沒有了OutputCache,換成了ResponseCache,ResponseCache必須帶一個參數:Duration 單位爲秒,最少設置一秒鐘github
//.NET Core2.1作法
[ResponseCache(Duration = 5)]
public IActionResult About()
{
ViewBag.time = DateTime.Now.ToString("yyyy年MM月dd日 HH時mm分ss秒");
return View();
}
而後再瀏覽器請求這個視圖web
在瀏覽器的響應頭的Cache-Control 中出現max-age=5, Http協議對此的解釋是瀏覽器
客戶端將不會接受其保留時間大於指定的秒數的響應。 示例:
max-age=60
(60 秒),max-age=2592000
(1 個月)緩存
若是在瀏覽器中禁用緩存,那麼ResponseCache不會有任何效果服務器
Vary過濾mvc
[ResponseCache(VaryByHeader = "User-Agent", Duration = 5)] public IActionResult About() { ViewBag.time = DateTime.Now.ToString("yyyy年MM月dd日 HH時mm分ss秒"); return View(); }
關於vary在Http響應頭的做用就是:告訴緩存服務器或者CDN,我仍是同一個瀏覽器的請求,你給我緩存就好了,若是你換個瀏覽器去請求,那麼vary的值確定爲空,那麼緩存服務器就會認爲你是一個新的請求,就會去讀取最新的數據給瀏覽器spa
參考資料:http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html代理
在Http中 :no-store,請求和響應的信息都不該該被存儲在對方的磁盤系統中
[ResponseCache(Location = ResponseCacheLocation.None, NoStore = true)]
public IActionResult About()
{
ViewBag.time = DateTime.Now.ToString("yyyy年MM月dd日 HH時mm分ss秒");
return View();
}
ResponseCacheLocation.None是在Cache-Control設置一個no-cache屬性,讓瀏覽器不緩存當前這個URL
緩存配置(CacheProfiles)
在一個正常的項目中,確定有不少個控制器,可是不可能每一個控制器的緩存策略都同樣,這時候,咱們就須要一個緩存的配置來靈活應對這個問題
在mvc的服務注入的時候,咱們能夠在option裏面注入進咱們的緩存策略
services.AddMvc(option=> { option.CacheProfiles.Add("test1", new CacheProfile() { Duration = 5 }); option.CacheProfiles.Add("test2", new CacheProfile() { Location = ResponseCacheLocation.None, NoStore = true }); });
而後咱們在使用的時候,直接使用配置策略的名稱就行了
[ResponseCache(CacheProfileName = "test1")]
public IActionResult About()
{
ViewBag.time = DateTime.Now.ToString("yyyy年MM月dd日 HH時mm分ss秒");
return View();
}
這樣咱們就能和以前在特性後邊配置同樣了,這是視圖緩存