背景

缓存样式表,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标签:scriptlinkimg。所有你需要做的是在对应Html标签中追加asp-append-version="true"

<link rel="stylesheet" href="~/css/site.css" 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" /><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?}");});
}

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

如果不想缓存某个静态文件,修改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属性 

原文:http://www.cnblogs.com/xiaoliangge/p/7872050.html


.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com 

ASP.NET Core缓存静态资源相关推荐

  1. ASP.NET Core 缓存技术 及 Nginx 缓存配置

    前言 在Asp.Net Core Nginx部署一文中,主要是讲述的如何利用Nginx来实现应用程序的部署,使用Nginx来部署主要有两大好处,第一是利用Nginx的负载均衡功能,第二是使用Nginx ...

  2. nginx 配置静态文件目录_nginx缓存静态资源,只需几个配置提升10倍页面加载速度...

    nginx缓存静态资源,只需几个配置提升10倍页面加载速度 首先我们看图说话 这是在没有缓存的情况下,这个页面发送了很多静态资源的请求: 可以看到,静态资源占用了整个页面加载用时的90%以上,而且这个 ...

  3. nginx proxy_pass缓存静态资源html和js导致的问题

    正文 昨天拉取前端的静态资源到我电脑本地运行测试,发现不管怎么删发现还是旧的js, 最后重启了nginx解决了.查了下资料,网上说nginx的proxy_pass是会缓存静态资源的,我本地的nginx ...

  4. ASP.NET Core使用静态文件、目录游览与MIME类型管理

    前言 今天我们来了解了解ASP.NET Core中的静态文件的处理方式. 以前我们寄宿在IIS中的时候,很多静态文件的过滤 和相关的安全措施 都已经帮我们处理好了. ASP.NET Core则不同,因 ...

  5. ASP.NET Core:静态文件

    在Web开发中,如js脚本.css样式.图片等的静态文件通常占据了很大一部分.ASP.NET Core提供了三个中间件来处理这种针对静态文件的请求.利用它们我们不经可以将物理文件发布为通过http请求 ...

  6. Asp.Net Core 缓存的使用(译)

    原文:http://www.binaryintellect.net/articles/a7d9edfd-1f86-45f8-a668-64cc86d8e248.aspx 环境:Visual Studi ...

  7. asp.net core合并压缩资源文件引发的学习之旅

    0. 在asp.net core中使用BuildBundlerMinifier合并压缩资源文件 在asp.net mvc中可以使用Bundle来压缩合并css,js 不知道的见:http://www. ...

  8. 利用ASP .NET Core的静态文件原理实现远程访问Nlog日志内容及解决遇到的坑

    最近项目上试运行发现,很多时候网站出了问题或者某个功能不正常,常常需要运维人员去服务器里面查看一下日志,看看日志里面会产生什么异常,这样导致每次都要去远程服务器很不方便,有时服务器是客户保管的不能让我 ...

  9. 细说ASP.NET Core静态文件的缓存方式

    一.前言 我们在优化Web服务的时候,对于静态的资源文件,通常都是通过客户端缓存.服务器缓存.CDN缓存,这三种方式来缓解客户端对于Web服务器的连接请求压力的. 本文指在这三个方面,在ASP.NET ...

最新文章

  1. LeetCode - 69. x 的平方根
  2. 用Python绘制一套“会跳舞”的动态图形给你看看
  3. 计算机硬件故障处理及维护,计算机硬件故障处理与维护方法
  4. linux centos7 cuda安装
  5. js日期格式化写法及获取当前日期年月日、上一月
  6. 77 ~And, two stars meet again~ RC汉化补丁[BUG修正]
  7. .net Core使用RabbitMQ
  8. [Algorithm NLP] 文本深度表示模型——word2vecdoc2vec词向量模型
  9. 凑热闹买了个小米剃须刀
  10. HDU 5025 Saving Tang Monk
  11. linux下安装sg11,Linux安装SG11加密扩展组件教程
  12. Java软件工程师职位分析
  13. 【Python】B样条曲线绘制
  14. [DAX] SUM函数 | SUMX函数
  15. Jmeter中线程组对Sampler和对循环控制器的作用
  16. 2022年基础设施行业10大技术应用趋势
  17. 三款过CE/FCC/SRCC认证USB接口双频WIFI模块
  18. 程序员阵线联盟 之歌
  19. java 自定义taglib_[JSP]自定义标签库taglib
  20. 如何使用12tool二维码合成器将多张二维码图片生成一张动态GIF图?

热门文章

  1. 构建iscsi网络存储服务
  2. CAD数据与ArcGIS数据的互转换(转载)
  3. windows server 2012 dhcp 配置故障转移
  4. 企业形象广告的几个突破要点
  5. .NET7的七项重大改进!
  6. iNeuOS工业互联网操作系统,矿山动态产量计量系统和铁路车辆识别系统应用场景案例...
  7. ABP Framework 5.0 RC.1 新特性和变更说明
  8. 重要更新,Office Add-in将全面支持Webview2
  9. 通过Dapr实现一个简单的基于.net的微服务电商系统(五)——一步一步教你如何撸Dapr之状态管理...
  10. Magicodes.IE 2.5版本发布