.Net Core 中间件与过滤器

embedded/2024/11/15 0:29:56/

过滤器这个是.Net MVC旧有的功能,中间件这个概念是新出的,

ASP.NET Core只是完成了HTTP请求调度、报文解析等必要的工作,像检查用户身份、设置缓存报文头等操作都是在中间件中完成中间件就是ASP.NET Core的一个组件,由前逻辑、next、后逻辑3部分组成,多个中间件组成一个管道,一个系统中可以有多个管道。ASP.NET Core执行的过程就是http请求和响应按照中间件组装的顺序在中间件之间流转的过程。

以前有封装过滤器进行用户身份检查、预处理请求数据,中间件的同样能完成,中间件的范围更广

var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();
//定义了对/test路径请求的处理,4-22为一个管道
app.Map("/test", async appbuilder => {//声明第一个中间件appbuilder.Use(async (context, next) => {context.Response.ContentType = "text/html";await context.Response.WriteAsync("1  Start<br/>");await next.Invoke();//执行下一个中间件await context.Response.WriteAsync("1  End<br/>");});//声明第二个中间件appbuilder.Use(async (context, next) => {await context.Response.WriteAsync("2  Start<br/>");await next.Invoke();await context.Response.WriteAsync("2  End<br/>");});//中间件执行完成后,执行runappbuilder.Run(async ctx => {await ctx.Response.WriteAsync("hello middleware <br/>");});
});
app.Run();
//注意,如果在中间件中使用ctx.Response.WriteAsync等方式向客户端发送响应,我们就不能
//再执行next.Invoke了把请求转到其他中间件了,因为其他中间件可能会对response进行了修改
//该案例仅仅当做演示
public class CheckAndParsingMiddleware
{private readonly RequestDelegate next;public CheckAndParsingMiddleware(RequestDelegate next){this.next = next;}//中间件的前逻辑、next、后逻辑都在这里public async Task InvokeAsync(HttpContext context){string pwd = context.Request.Query["password"];if (pwd=="123"){context.Items["BodyJson"] = "hellowrld";await next(context);//传递到下一个中间件}else{context.Response.StatusCode = 401;//不会传递到下一个中间件}}
}
var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();
app.Map("/test", async appbuilder => {appbuilder.UseMiddleware<CheckAndParsingMiddleware>();//按注册顺序,执行中间件类的Invoke方法appbuilder.Run(async ctx => {Console.WriteLine("run start");ctx.Response.ContentType = "text/html";ctx.Response.StatusCode = 200;//HttpContext.Item在同一次请求中是共享的,用它来实现中间件之间数据的传递await ctx.Response.WriteAsync(ctx.Items["BodyJson"].ToString());Console.WriteLine("run end");});
});
app.Run();


http://www.ppmy.cn/embedded/46079.html

相关文章

JVM监控-JMX探针的安装和使用

jvm监控的搭建和使用 ​ Java Management Extensions&#xff08;JMX&#xff09;是一种Java标准&#xff0c;用于管理和监控Java应用程序&#xff0c;特别是分布式系统。它提供了一种标准化的方式来管理应用程序的各种方面&#xff0c;包括性能监控、配置更改、事件通知等。目…

美创科技获评“2024年第一批浙江省专精特新中小企业”!

近日&#xff0c;由浙江省经济和信息化厅组织开展的“2024年第一批浙江省专精特新中小企业”名单公示结束。 美创科技通过严格筛选&#xff0c;凭借在数据安全领域的专业化能力以及创新实践成果&#xff0c;获评浙江省年度首批“专精特新”中小企业&#xff01; “专精特新”是…

某商业落地充电桩后台服务器通迅协议V2.28 开源 | 嘎嘎快充充电桩平台V2(支持 汽车 电动自行车 云快充1.5、云快充1.6 单体服务 )

嘎嘎快充开源充电桩平台 源码下载地址https://gitee.com/itholiday 充电桩与后台服务器 通讯协议 V2.28 目录 1 网络拓扑 1.1 功能界定&#xff1a; 1.1.1 充电机智能终端 1.1.2 智能中心管理系统 1.2 接口定义&#xff1a; 1.3 通讯方式&#xff1a; 1.4 通信规约 1.5…

华为OD刷题C卷 - 每日刷题 6 (求字符串中所有整数的最小和、求满足条件的最长子串的长度)

两段代码分别解决了两个字符串处理的问题&#xff0c;下面是对它们的概述&#xff1a; 1、&#xff08;求字符串中所有整数的最小和&#xff09;&#xff1a; 这段代码是解决“求字符串中所有整数的最小和”的问题。它提供了一个Java类Main&#xff0c;其中包含一个方法getMi…

HQChart使用教程100-uniapp如何在vue3运行微信小程序

HQChart使用教程100-uniapp如何在vue3运行微信小程序 症状原因分析解决思路解决步骤1. 修改vender.js2. 修改HQChartControl.js 完整实例HQChart代码地址 症状 HQChart插件在uniappvue3的项目编译成小程序以后&#xff0c; 运行会报错&#xff0c;见下图。 原因分析 查了下…

Docker安装Redis(云服务器)

准备&#xff1a; 在云服务器中开启6370端口号 docker run -d --name redis -p 6379:6379 redis 这条命令使用docker运行一个名为"redis"的容器&#xff0c;映射容器的6379端口到主机的6379端口&#xff0c;并且使用redis镜像来运行容器。REDIS是一个开源的内存数据…

手机号脱敏

手机号脱敏 // 手机号脱敏subTelephone(telphone) {let result telphone.substr(0, 4) **** telphone.substr(8);return result;},

第九周:员工激励理论

1. 关注自己到关注他人 你是激励者&#xff0c;也会是被激励者。 虽然每个人的价值观不一样&#xff0c;但要做好激励员工这件事情&#xff0c;我觉得可以从自身角度出发&#xff0c;可以问问自己&#xff0c;你是如何被激励的&#xff1f; 如果是我&#xff0c;就只想要钱&…