• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >ASP.NET > 详解ASP.NET Core 中间件之压缩、缓存

详解ASP.NET Core 中间件之压缩、缓存

作者:杨晓东 字体:[增加 减小] 来源:互联网 时间:2017-05-11

杨晓东通过本文主要向大家介绍了pro asp.net core mvc,asp core h5,asp core area,asp中间件,asp等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

前言

今天给大家介绍一下在 ASP.NET Core 日常开发中用的比较多的两个中间件,它们都是出自于微软的 ASP.NET 团队,他们分别是Microsoft.AspNetCore.ResponseCompression 和 Microsoft.AspNetCore.ResponseCaching , 下面让我们一起看看的功能以及如何去使用吧。

Getting Started

Microsoft.AspNetCore.ResponseCompression

Microsoft.AspNetCore.ResponseCompression 这个中间件是 .NET Core 1.1 版本中新增加的,看名字应该知道,它主要是负责对输出的内容进行压缩, 那么在我们WEB开发中主要就是 GZip 压缩了。

Gzip 压缩是我们在 WEB 中经常会使用的一项性能优化技术,它可以对页面输出的内容使用压缩算法(GZip)进行体积的压缩, 那在以前的时候,我们可以使用 IIS 来做这项工作,但是现在我们的程序脱离 IIS了,就必须有一个中间件来帮我们做这件事情了,它就是我们要介绍的这个中间件。

1、添加 Microsoft.AspNetCore.ResponseCompression 包

你可以使用 Visual Studio 打开 NuGet 包管理器控制台输入一下命令安装

Install-Package Microsoft.AspNetCore.ResponseCompression
</div>

也可以使用 NuGet包管理器UI界面安装。

添加完成之后,你就可以在 project.json 中看到你添加的包了。注意目前版本是 1.0.0.

2、更新 Startup.cs 文件

修改 Startup , 在ConfigureServices 和Configure 两个方法中添加如下代码:

public class Startup
{
  ...
 
  public void ConfigureServices(IServiceCollection services)
  {
    services.AddResponseCompression();
    
    ...
  }
 
  public void Configure(IApplicationBuilder app, ILoggerFactory loggerFactory)
  {
    app.UseResponseCompression();
    
    ...
  }
}
</div>

现在你就可以测试一下输入的 Http Response 是否被压缩了。

前:

后:

通过 前 后 对比,可以看出来,在 Response Headers 里面多了一个 Content-Encoding:gzip 的头部信息,说明我们的中间件生效了。

Microsoft.AspNetCore.ResponseCaching

Microsoft.AspNetCore.ResponseCaching 这个中间件也是 .NET Core 1.1 版本中新增加的,同样看名字应该知道,它主要是负责对输出的内容进行缓存设置。在以前我们可以同样在 IIS 中设置这些东西,但是粒度可能并没有这么细。

我之前写过一篇关于 ASP.NET Core 缓存的文章,里面介绍了 ASP.NET Core MVC 中的 Response 缓存,它是通过一个 ResponseCacheAttribute 来实现的设置缓存头信息:

[ResponseCache(VaryByHeader ="Accept-Encoding", Location = ResponseCacheLocation.Any, Duration = 10)]
public IActionResult About()
{
}
</div>

那,除了 MVC 提供的 ResponseCacheAttribute 外,还有另外一种方式设置缓存头信息,如下:

public IActionResult About()
{
  Response.GetTypedHeaders().CacheControl = new CacheControlHeaderValue()
  {
    Public = true,
    MaxAge = TimeSpan.FromSeconds(10)
  };
  Response.Headers[HeaderNames.Vary] = new string[] { "Accept-Encoding" };
}
</div>

这两种方式,最终的效果是一致的。

有了这些头信息之后,我们就可以在服务端里面这个中间件干些什么事情了。所以,该中间件将会在适当的时候读取这些头信息,然后缓存到本地缓存里面,当再有请求进来的时候会直接跳过action,读取缓存信息进行返回。

下面,我们一起来看看怎么样添加到我们的项目中吧,很简单。

1、添加 Microsoft.AspNetCore.ResponseCaching 包

你可以使用 Visual Studio 打开 NuGet 包管理器控制台输入一下命令安装

Install-Package Microsoft.AspNetCore.ResponseCaching
</div>

2、更新 Startup.cs 文件

修改 Startup , 在ConfigureServices 和Configure 两个方法中添加如下代码:

public class Startup
{
  ...
 
  public void ConfigureServices(IServiceCollection services)
  {
    services.AddResponseCaching();
    
    ...
  }
 
  public void Configure(IApplicationBuilder app, ILoggerFactory loggerFactory)
  {
    app.UseResponseCaching();
    
    ...
  }
}
</div>

输入的头信息如下:

详细示例可以看这里.

注意:上面的示例在 Chrome 浏览器中,当你按 F5 或者右键刷新页面时候, Http Response Header 中的 Control-Cache: max-age 有时候可能会不生效,这是因为 Chrome 浏览器有很智能的算法来猜测你当前的行为是真的想刷新还是取缓存。 所以你可以试着把你的地址放入到一个HTML的Link中或者新开一个选项卡键入地址尝试。而Edge和IE浏览器行为是符合预期的。

总结

以上是这两个中间件的功能及使用方法,很简单,就不多说了,希望对大家的学习有所帮助,也希望大家多多支持。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • ASP.NET Core发送邮件的方法
  • 在ASP.NET Core 中发送邮件的实现方法(必看篇)
  • Asp.net core WebApi 使用Swagger生成帮助页实例
  • ASP.NET core Web中使用appsettings.json配置文件的方法
  • ASP.NET Core部署前期准备 使用Hyper-V安装Ubuntu Server 16.10
  • ASP.NET Core应用中与第三方IoC/DI框架的整合
  • ASP.NET Core程序发布到Linux生产环境详解
  • 详解ASP.NET Core 网站发布到Linux服务器
  • ASP.NET Core全面扫盲贴
  • 基于ASP.NET Core数据保护生成验证token示例

相关文章

  • 2017-05-11ASP.NET中Label控件用法详解
  • 2017-05-11ASP.NET对HTML页面元素进行权限控制(二)
  • 2017-05-11基于ASP.NET+EasyUI框架实现图片上传提交表单功能(js提交图片)
  • 2017-05-11asp.net 支持多语言站点的实现方法
  • 2018-08-20如何利用HttpClientFactory实现简单的熔断降级
  • 2017-05-11asp.net 身份验证(最简单篇)
  • 2017-05-11asp.net下UTF-7转GB2312编码的代码(中文)
  • 2017-05-11asp.net用Zxing库实现条形码输出的具体实现
  • 2017-08-02asp.net动态更新
  • 2017-05-11asp.net Page.EnableEventValidation 属性验证服务器控件的回发和回调事件出现的错误

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C#数据导入/导出Excel文件及winForm导出Execl总结
    • .NET中文乱码的解决方法分享
    • asp.net(C#)跨域及跨域写Cookie问题
    • asp.net下遍历页面中所有的指定控件的代码
    • Asp.net配合easyui实现返回json数据实例
    • 删除特殊字符和限定用户输入长度的示例代码
    • Web里URL空格的转换方法
    • asp.net Javascript 的几种写法与提示
    • asp.net GridView中超链接的使用(带参数)
    • 判断WebBrowser浏览器网页加载完成的处理方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有