ASP.NET 6 中间件系列 - 条件中间件

这篇文章是 ASP.NET 6 中间件系列文章的第 4 部分。

到目前为止,我们已经介绍了 ASP.NET 6 中间件的基础知识,展示了如何创建自定义中间件类,并讨论了中间件执行顺序的重要性。

在本系列的最后一部分中,我们将展示在管道中有条件地执行中间件的两种方法:

  1. 采用 AppSettings.json 文件中的设置,来确定是否要添加中间件到管道中;

  2. 通过使用传入请求的数据,有条件地执行已经在管道中的中间件。

6a6352135715ecd944fdf9595414a109.png

基于 AppSettings 的条件中间件

让我们回顾一下,上一篇文章中的TimeLoggingMiddleware类:

using MiddlewareNET6Demo.Logging;
using System.Diagnostics;namespace  MiddlewareNET6Demo.Middleware
{public  class  TimeLoggingMiddleware{private  readonly RequestDelegate _next;private  readonly ILoggingService _logger;public TimeLoggingMiddleware(RequestDelegate next, ILoggingService logger){_next = next;_logger = logger;}public async Task InvokeAsync(HttpContext context){Stopwatch watch = new Stopwatch();watch.Start();await _next(context);watch.Stop();_logger.Log(LogLevel.Information, "Time to execute: " + watch.ElapsedMilliseconds + " milliseconds.");}}
}

现在,我们只希望在特定的条件(比如,当我们在追踪一个 BUG,或者应用程序运行缓慢等)下将TimeLoggingMiddleware添加到应用程序管道中。

为了有条件地向管道中添加中间件,我们可以在 AppSettings.json 文件中设置一个可以在Program.cs中读取的字段。

在 AppSettings.json 文件中添加一个名为MiddlewareSettings的配置字段,以及一个名为UseTimeLoggingMiddleware的配置项:

{"Logging": {"LogLevel": {"Default": "Information","Microsoft.AspNetCore": "Warning"}},"AllowedHosts": "*","MiddlewareSettings": {"UseTimeLoggingMiddleware": "true",}
}

我们还需要一个类来保存这些设置的值。按照约定,类名应该与配置字段名MiddlewareSettings匹配,而属性名应该与配置项名UseTimeLoggingMiddleware匹配:

namespace  MiddlewareNET6Demo
{public  class  MiddlewareSettings{public  bool UseTimeLoggingMiddleware { get; set; }}
}

然后,在 Program.cs 文件中,我们可以读取 AppSettings.json 的那一部分,并将其映射到MiddlewareSettings类的的一个实例上:

var builder = WebApplication.CreateBuilder(args);builder.Services.AddRazorPages();
builder.Services.AddTransient<ILoggingService, LoggingService>();var app = builder.Build();var middlewareSettings = builder.Configuration.GetSection("MiddlewareSettings").Get<MiddlewareSettings>();

只有当middlewareSettings实例的UseTimeLoggingMiddleware属性值为true时,我们才能将TimeLoggingMiddleware添加到管道中:

//...if(middlewareSettings.UseTimeLoggingMiddleware)app.UseTimeLoggingMiddleware();//...

通过这种方式,我们可以根据应用程序的设置,来控制哪个中间件在管道中处于活动状态。

基于请求 URL 的条件中间件

另一种方法可能带有欺骗性质,因为中间件总是会被添加到管道中,但是它除了将执行传递给下一个中间件之外,不会做任何其它事情。

假设我们有一个新的中间件类叫做CultureMiddleware:

using System.Globalization;namespace  MiddlewareNET6Demo.Middleware
{public  class  CultureMiddleware{private  readonly RequestDelegate _next;public CultureMiddleware(RequestDelegate next){_next = next;}public async Task InvokeAsync(HttpContext context){var cultureQuery = context.Request.Query["culture"];if (!string.IsNullOrWhiteSpace(cultureQuery)){var culture = new CultureInfo(cultureQuery);CultureInfo.CurrentCulture = culture;CultureInfo.CurrentUICulture = culture;}await _next(context);}}
}

请注意,该中间件仅在传入请求中存在culture请求参数时,才会执行一些实际工作。

如果该参数存在,中间件将应用程序的当前区域设置为传入参数的值。

例如,如果我们提交了以下请求:

http://codeman.tech/post/123?culture=zh-CN

CultureMiddleware会将应用的区域设置为zh-CN,然后再进行其它正常的处理。

如果传入的请求是:

http://codeman.tech/post/123

那么,中间件将会什么都不做,应用程序的区域仍然是默认的。

这种有条件地执行中间件的方法,比 AppSettings.json 解决方案提供了更细粒度的执行控制,但潜在的代价是始终需要将中间件添加到管道中。

TimeLoggingMiddleware为例:

如果传入的请求包含特定的值,才执行TimeLoggingMiddleware的代码;

在 MVC 应用程序,也许我们只想记录单个控制器的执行时;

在 Razor 应用中,可能只想记录有问题的页面;

在 Web API 中,只是其中一个端点有些慢。

在这些情况下,我们都可以使用这种方法将TimeLoggingMiddleware定位到我们想要记录的内容。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/288862.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

服务器之Apache和Tomcat和Nginx的理解和对比

1 问题 公司服务器用的Apache,后台是php语言&#xff0c;然后服务端用的linux C/C,会经常听到Apache服务器&#xff0c;然后之前实习的公司服务端用的java,然后依稀记得使用了nginx反向代理服务器和tomcat&#xff0c;请求先经过nginx然后再去通过tomcat转发请求&#xff0c;然…

python数据结构教程_利用Python演示数型数据结构的教程

使用 Python 内建的defaultdict方法可以轻松定义一个树的数据结构。简单的说树也可以是一个字典数据结构def tree(): return defaultdict(tree)这就是全部&#xff0c;就一行代码。如果你继续下面的代码&#xff0c;需要先引入from collections import defaultdict实例JSON-esq…

[Programming WCF Services]Chapter 1. WCF Essentials - Metadata Exchange

1.HTTP-GET WCF 方式 通过Http的方式提供metadata 1.1.配置文件方式 <system.serviceModel><services><service name "MyService" behaviorConfiguration "MEXGET"><host><baseAddresses><add baseAddress "http…

【C语言简单说】十四:for循环

说到了循环&#xff0c;我们的内容也就差不多了&#xff0c;此内容并不深入讲解太多东西&#xff0c;大家学习完&#xff0c;如果要深入的话可以查看相关书籍&#xff0c;详细大家学习完后可能会觉得看书上说的可能就看懂了。 可能会有人说为什么不说进制&#xff1f;或者说位…

C#读文件操作

using System; using System.IO;namespace IO操作 {class Program{private const string FILE_NAME"IO.txt";static void Main(string[] args){if (!File.Exists(FILE_NAME)){Console.WriteLine("{0}does not exists!",FILE_NAME);Console.ReadLine();retu…

使用RxJava从多个数据源获取数据

试想&#xff0c;需要一些动态数据的时候&#xff0c;只要每次都请求网络就可以了。但是&#xff0c;更有效率的做法是&#xff0c;把联网得到的数据&#xff0c;缓存到磁盘或内存。 具体的说&#xff0c;计划如下&#xff1a; 偶尔的联网操作&#xff0c;只为获取最新数据。 …

centos 零碎学习小记 2.

1.具体实验&#xff08;让网卡ethX 里设置的DNS&#xff0c;不影响DNS配置文件 /etc/resolv.conf&#xff09;1.装完系统的人都想把机器连接外网&#xff0c;都会先看看自己网卡。那么我们用神马呢?简单实用 #ifconfig -a 看看自己网卡信息2.网卡看了开始设置您的网络吧&#…

AspNetCore配置多环境log4net配置文件

前言在之前的文章中有讲到AspNetCore多环境配置文件的应用&#xff0c;我们根据自己多种环境分别配置多个appsettings.$EnvironmentName.json文件。在实际的开发中我们可能会遇到不只一个配置文件&#xff0c;如当我们使用log4net日志库时&#xff0c;喜欢使用单独的log4net.co…

java阻塞队列作用_简单理解阻塞队列(BlockingQueue)中的take/put方法以及Condition存在的作用...

简单理解阻塞队列(BlockingQueue)中的take/put方法以及Condition存在的作用Condition&#xff1a;可以理解成一把锁的一个钥匙&#xff0c;它既可以解锁(通知放行)&#xff0c;又可以加锁(阻塞)notFull&#xff1a;当队列元素满了时&#xff0c;阻塞生产&#xff0c;当队列元素…

剑指offer之找出数组中重复数字

1 问题 给的N个数字的数组&#xff0c;每个元素的大小范围大于等于0小于N(0 << a[i] < N),找出数组中有哪些数字重复了并且这个数字重复了多少次&#xff0c;一共有几个数字重复了。 2思路 由于元素的大小范围大于等于0小于N(0 << a[i] < N),我们直接把这个…

tcp udp区别优缺点_一文搞懂TCP与UDP的区别

一、TCP协议&#xff1a;位于传输层&#xff0c; 提供可靠的字节流服务。所谓的字节流服务(Byte Stream Service) 是指&#xff0c; 为了方便传输&#xff0c; 将大块数据分割成以报文段(segment) 为单位的数据包进行管理。而可靠的传输服务是指&#xff0c; 能够把数据准确可靠…

C#趣味程序---水仙花数

using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms;namespace 水仙花数 {public partial class Fo…

《企业级ios应用开发实战》一导读

前 言 为什么写这本书随着我国3G网络和移动互联网的兴起&#xff0c;许多传统的企业应用正在从桌面向移动终端扩展&#xff0c;移动办公、移动营销、移动作业等需求日渐强烈。有迹象表明&#xff0c;传统的互联网正在向移动互联网发展。根据摩根士丹利发布的全球互联网发展趋势…

java获取map数量_java – 如何从HashMap或LinkedHashMap获取有限数量的值?

假设我有一个包含216个条目的LinkedHashMap,我如何从LinkedHashMap< Integer,Object>获取前100个值(此处为Object类型).解决方法:丑陋的单线这个丑陋的单线程会做(并在问题的情况下返回一个ArrayList< Object>)&#xff1a;Collections.list(Collections.enumerati…

对.NET未来的一点感悟

.NET诞生有20年了&#xff0c;一路走来起起伏伏&#xff0c;从开始的专注windows&#xff0c;到后来的跨平台&#xff1b;从之前的闭源&#xff0c;到现在的完全开源&#xff1b;从原来的win server(IIS)&#xff0c;到现在的紧密拥抱docker&#xff0c;.NET在成长&#xff0c;…

linux之安装frida遇到的问题

我想安装Hook家族神器的Frida工具 问题1 我一开始使用的命令如下 sudo pip install frida 然后提示错误如下 The directory /home/chenyu/.cache/pip/http or its parent directory is not owned by the current user and the cache has been disabled. Please check the …

为什么要选择Hibernate

2019独角兽企业重金招聘Python工程师标准>>> 见&#xff1a; http://onecan.iteye.com/blog/1387920 转载于:https://my.oschina.net/sniperLi/blog/416396

苹果手机5s无需越狱免流_苹果越狱手机端自签名插件

unc0ver越狱官网&#xff1a; https://github.com/pwn20wndstuff/Undecimus (此网站ipa需要签名)已经签名网站&#xff1a; https://jailbreaks.fun/支持iOS11.0~12.1.3~12.4 支持 iPhone5S/SE/6/6P/6S/6SP…

面向对象之迪米特法则

转自&#xff1a;http://my.oschina.net/shyl/blog/531542 <?phpclass Teacher {//老师对学生发布命令,清一下女生public function commond(GroupLeader $groupLeader){//初始化女生for($i0; $i<20; $i){$listGirls[] new Girl();}//告诉体育委员开始执行清查任务$grou…

【C语言简单说】十五:while循环

上一节说了for循环&#xff0c;那么我们说一下while循环&#xff1b;其实都是循环&#xff0c;就好比肯德基和徳啃鸡一样&#xff0c;卖的都是鸡~ ㄟ(▔&#xff3e;▔ㄟ) (╯▔&#xff3e;▔)╯ 上代码&#xff1a; #include<stdio.h> #include<stdlib.h> int…