asp.net core缓存静态资源示例详解 -下载和记娱乐
背景缓存样式表,javascript或图像文件等静态资源可以提高您网站的性能。在客户端,总是从缓存中加载一个静态文件,这样可以减少对服务器的请求数量,从而减少获取页面及其资源的时间。在服务器端,由于它们的请求较少,服务器可以处理更多的客户端而无需升级硬件。
虽然缓存是一件好事,但您必须确保客户端始终运行最新版本的应用程序。当您部署下一个版本的网站时,您不希望客户端使用过时的缓存版本的文件。方案:为确保用户始终使用最新版本的文件,我们必须为每个文件版本提供一个唯一的url。有很多策略:使用查询字符串: http://sample。
com/file。js?v=123 重命名文件: http://sample。com/file。123。js 创建一个目录: http://sample。com/123/file。jsasp。net core提供了一种使用 taghelper来追加版本与查询字符串的机制。
它支持以静态资源为目标的最常见的html标签:script,link和img。所有你需要做的是在对应html标签中追加asp-append-version=”true” :css” rel=”external nofollow” asp-append-version=”true” />svg” asp-append-version=”true” />在浏览器中的展现:每个文件都会有对应的v值,并存储在一个imemorycache文件的url现在是唯一的,并且会在文件更改时更改,所以我们可以将缓存头添加到响应中,以指示客户端文件可以永久存储在缓存中实践为了指示浏览器将文件存储在缓存中,我们必须发送cache-control头文件和expires头文件以实现http/1。
0兼容性。为了添加这些头文件,我们使用了onprepareresponse回调函数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?}”); });}可以查看开发者控制台,发现静态资源都被缓存:如果不想缓存某个静态文件,修改startup。
cs文件:app。usestaticfiles(new staticfileoptions { onprepareresponse = context => { //缓存一年 //以下操作是usestaticfiles内部默认实现 if (!string。
isnullorempty(context。context。request。query[“v”]))//资源添加asp-append-version=”true”后v是查询参数 { //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 } } });会发现无论怎么刷新,site。
js?v=7mknbu1tgql1bueze3j2r151hklhldko4bbar-iqcy0文件永远都是重新请求,并没有使用缓存机制结论使用http缓存对于性能方面的原因(客户端和服务器端)非常重要。使用asp。net core,您可以利用提供的功能taghelpers来生成版本控制的url,并更改默认配置staticfilesmiddleware为资源urls添加header的cache-control属性 。
1.文章《asp.net core缓存静态资源示例详解》援引自互联网,为网友投稿收集整理,仅供学习和研究使用,内容仅代表作者本人观点,与本网站无关,侵删请点击页脚下载和记娱乐的联系方式。
2.文章《asp.net core缓存静态资源示例详解》仅供读者参考,本网站未对该内容进行证实,对其原创性、真实性、完整性、及时性不作任何保证。