您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關(guān)如何在ASP.NET Core中緩存靜態(tài)資源,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
ASP.NET Core提供了一種使用 TagHelper來追加版本與查詢字符串的機制。它支持以靜態(tài)資源為目標的最常見的HTML標簽:script,link和img。所有你需要做的是在對應Html標簽中追加asp-append-version="true"
:
<link rel="stylesheet" href="~/css/site.css" rel="external nofollow" asp-append-version="true" /> <script src="~/js/site.js" asp-append-version="true"></script> <img src="~/images/banner1.svg" asp-append-version="true" />
在瀏覽器中的展現(xiàn):
<link rel="stylesheet" href="/css/site.css?v=1wp5zz4e-mOPFx4X2O8seW_DmUtePn5xFJk1vB7JKRc" rel="external nofollow" /> <script src="/js/site.js?v=EWaMeWsJBYWmL2g_KkgXZQ5nPe-a3Ichp0LEgzXczKo"></script> <img src="/images/banner1.svg?v=GaE_EmkeBf-yBbrJ26lpkGd4jkOSh2eVKJaNOw9I4uk" />
每個文件都會有對應的V值,并存儲在一個IMemoryCache
文件的URL現(xiàn)在是唯一的,并且會在文件更改時更改,所以我們可以將緩存頭添加到響應中,以指示客戶端文件可以永久存儲在緩存中
實踐
為了指示瀏覽器將文件存儲在緩存中,我們必須發(fā)送Cache-control頭文件和Expires頭文件以實現(xiàn)HTTP/1.0兼容性。為了添加這些頭文件,我們使用了OnPrepareResponse回調(diào)函數(shù)StaticFilesOptions。我們來修改這個Startup.cs文件:
public void Configure(IApplicationBuilder app, IHostingEnvironment env) { app.UseStaticFiles(new StaticFileOptions { OnPrepareResponse = context => { //緩存一年 if (!string.IsNullOrEmpty(context.Context.Request.Query["v"])) { context.Context.Response.Headers.Add("cache-control", new[] { "public,max-age=31536000" }); context.Context.Response.Headers.Add("Expires", new[] { DateTime.UtcNow.AddYears(1).ToString("R") }); // Format RFC1123 } } }); app.UseMvc(routes => { routes.MapRoute( name: "default", template: "{controller=Home}/{action=Index}/{id?}"); }); }
可以查看開發(fā)者控制臺,發(fā)現(xiàn)靜態(tài)資源都被緩存:
如果不想緩存某個靜態(tài)文件,修改Startup.cs文件:
app.UseStaticFiles(new StaticFileOptions { OnPrepareResponse = context => { //緩存一年 //以下操作是UseStaticFiles內(nèi)部默認實現(xiàn) if (!string.IsNullOrEmpty(context.Context.Request.Query["v"]))//資源添加asp-append-version="true"后v是查詢參數(shù) { //context.Context.Response.Headers.Add("cache-control", new[] { "public,max-age=31536000" }); context.Context.Response.Headers.Add("cache-control", new[] { "public,no-cache" }); context.Context.Response.Headers.Add("Expires", new[] { DateTime.UtcNow.AddYears(1).ToString("R") }); // Format RFC1123 } } });
會發(fā)現(xiàn)無論怎么刷新,site.js?v=7mkNbU1tgQL1bUeZe3j2R151hKLhLDKO4BBaR-iqCy0文件永遠都是重新請求,并沒有使用緩存機制
結(jié)論
使用HTTP緩存對于性能方面的原因(客戶端和服務器端)非常重要。使用ASP.NET Core,您可以利用提供的功能TagHelpers來生成版本控制的URL,并更改默認配置StaticFilesMiddleware為資源Urls添加header的Cache-control屬性 。
以上就是如何在ASP.NET Core中緩存靜態(tài)資源,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。