欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ASP.NET Core缓存静态资源示例详解

程序员文章站 2022-04-10 18:29:29
背景 缓存样式表,javascript或图像文件等静态资源可以提高您网站的性能。在客户端,总是从缓存中加载一个静态文件,这样可以减少对服务器的请求数量,从而减少获取页面及...

背景

缓存样式表,javascript或图像文件等静态资源可以提高您网站的性能。在客户端,总是从缓存中加载一个静态文件,这样可以减少对服务器的请求数量,从而减少获取页面及其资源的时间。在服务器端,由于它们的请求较少,服务器可以处理更多的客户端而无需升级硬件。

虽然缓存是一件好事,但您必须确保客户端始终运行最新版本的应用程序。当您部署下一个版本的网站时,您不希望客户端使用过时的缓存版本的文件。

方案:

为确保用户始终使用最新版本的文件,我们必须为每个文件版本提供一个唯一的url。有很多策略:

  • 使用查询字符串: http://sample.com/file.js?v=123
  • 重命名文件: http://sample.com/file.123.js
  • 创建一个目录: http://sample.com/123/file.js

asp.net core提供了一种使用 taghelper来追加版本与查询字符串的机制。它支持以静态资源为目标的最常见的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" />

在浏览器中的展现:

<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-ybbrj26lpkgd4jkosh1evkjanow9i4uk" />

每个文件都会有对应的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?}");
 });
}

 可以查看开发者控制台,发现静态资源都被缓存:

ASP.NET Core缓存静态资源示例详解 

如果不想缓存某个静态文件,修改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文件永远都是重新请求,并没有使用缓存机制

 ASP.NET Core缓存静态资源示例详解

结论

使用http缓存对于性能方面的原因(客户端和服务器端)非常重要。使用asp.net core,您可以利用提供的功能taghelpers来生成版本控制的url,并更改默认配置staticfilesmiddleware为资源urls添加header的cache-control属性 。

ASP.NET Core缓存静态资源示例详解 

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。