聊聊 ASP.NET Core 中间件(二):中间件和筛选器的区别

简介: 聊聊 ASP.NET Core 中间件(二):中间件和筛选器的区别

前言

有些小伙伴看到上一篇文章后,可能会发现中间件和我们之前讲的筛选器非常类似,比如它们都是通过 next 串起来的一系列的组件,并且都可以在请求处理前后执行代码,都可以通过不执行 next 来进行请求的终止。那么筛选器和中间件有什么区别呢?有了筛选器,为什么还要有中间件呢?今天我们一起来学习下它们之间的差异。

正文

在 ASP.NET Core 中,中间件(Middleware)和筛选器(Filter)实际上是两种不同的概念,它们在处理请求和响应过程中有着不同的作用,我们首先来看看他们的概念和作用。

  1. 中间件
  • 中间件是 ASP.NET Core 请求处理管道中的组件,用于处理请求和生成响应。
  • 中间件是一种轻量级、可重用的组件,可以按照一定的顺序添加到请求处理管道中。
  • 中间件可以在请求处理管道的不同阶段执行逻辑,例如日志记录、身份验证、异常处理等。
  • 中间件是全局性的,对整个应用程序生效,可以跨越不同的控制器和动作。
  • 中间件是基于委托(Delegate)的,使用 UseMiddleware 方法将中间件添加到应用程序启动时的请求处理管道中。
  1. 筛选器
  • 筛选器是 ASP.NET Core MVC 中的一种功能,用于在执行 MVC 控制器动作之前或之后执行一些逻辑。
  • 筛选器可以用于实现日志记录、授权验证、异常处理等功能。
  • 筛选器可以分为全局筛选器、控制器筛选器、动作筛选器、结果筛选器和异常筛选器等,每种筛选器的执行时机不同。
  • 筛选器是 MVC 特定的,只对 MVC 控制器和动作生效。
  • 筛选器是基于接口的,需要实现相应的接口并注册到服务容器中。

结论:筛选器与中间件区别和使用建议

  1. 中间件是 ASP.NET Core 中提供的功能,而筛选器是 ASP.NET Core MVC 中提供的功能
  2. ASP.NET Core MVC 是由 MVC 中间件提供的框架,而筛选器属于 MVC 中间件提供的功能,即中间件和筛选器所处的层级是不同的,中间件是一个基础的概念,而筛选器是 MVC 中间件中的机制
  3. 中间件可以处理所有的请求,无论是针对控制器的请求还是针对静态文件等的请求,而筛选器只能处理对控制器的请求,仅作用于 MVC 控制器和动作
  4. 从底层实现上看,中间件是基于委托的,而筛选器是基于接口的
  5. 中间件运行在一个更底层、更抽象的级别,因此在中间件中无法处理 IActionResult、ActionDescriptor 等 MVC 中间件特有的概念
  6. 因为中间件工作在比筛选器更低的层级中,因此在实现同样的功能的时候,中间件的运行效率更高
  7. 在开发一个对请求进行前后逻辑编程的组件的时候,优先选择使用中间件;但是如果这个组件只针对 MVC 或者需要调用一些与 MVC 相关的类的时候,就只能选择筛选器


相关文章
|
5天前
|
开发框架 .NET 开发者
简化 ASP.NET Core 依赖注入(DI)注册-Scrutor
Scrutor 是一个简化 ASP.NET Core 应用程序中依赖注入(DI)注册过程的开源库,支持自动扫描和注册服务。通过简单的配置,开发者可以轻松地从指定程序集中筛选、注册服务,并设置其生命周期,同时支持服务装饰等高级功能。适用于大型项目,提高代码的可维护性和简洁性。仓库地址:<https://github.com/khellang/Scrutor>
23 5
|
24天前
|
开发框架 .NET C#
在 ASP.NET Core 中创建 gRPC 客户端和服务器
本文介绍了如何使用 gRPC 框架搭建一个简单的“Hello World”示例。首先创建了一个名为 GrpcDemo 的解决方案,其中包含一个 gRPC 服务端项目 GrpcServer 和一个客户端项目 GrpcClient。服务端通过定义 `greeter.proto` 文件中的服务和消息类型,实现了一个简单的问候服务 `GreeterService`。客户端则通过 gRPC 客户端库连接到服务端并调用其 `SayHello` 方法,展示了 gRPC 在 C# 中的基本使用方法。
35 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
|
13天前
|
开发框架 缓存 .NET
GraphQL 与 ASP.NET Core 集成:从入门到精通
本文详细介绍了如何在ASP.NET Core中集成GraphQL,包括安装必要的NuGet包、创建GraphQL Schema、配置GraphQL服务等步骤。同时,文章还探讨了常见问题及其解决方法,如处理复杂查询、错误处理、性能优化和实现认证授权等,旨在帮助开发者构建灵活且高效的API。
22 3
|
2月前
|
开发框架 JavaScript 前端开发
一个适用于 ASP.NET Core 的轻量级插件框架
一个适用于 ASP.NET Core 的轻量级插件框架
|
7月前
|
消息中间件 存储 负载均衡
消息中间件的选择:RabbitMQ是一个明智的选择
消息中间件的选择:RabbitMQ是一个明智的选择
116 0
|
6月前
|
消息中间件 存储 中间件
【消息中间件】详解三大MQ:RabbitMQ、RocketMQ、Kafka
【消息中间件】详解三大MQ:RabbitMQ、RocketMQ、Kafka
1620 0
|
5月前
|
消息中间件 编解码 Docker
Docker部署RabbitMQ消息中间件
【7月更文挑战第4天】Docker部署RabbitMQ消息中间件
280 3
|
2月前
|
消息中间件 编解码 Docker
【Docker项目实战】Docker部署RabbitMQ消息中间件
【10月更文挑战第8天】Docker部署RabbitMQ消息中间件
118 1
【Docker项目实战】Docker部署RabbitMQ消息中间件
|
4月前
|
消息中间件 Java 测试技术
消息中间件RabbitMQ---SpringBoot整合RabbitMQ【三】
这篇文章是关于如何在SpringBoot应用中整合RabbitMQ的消息中间件。内容包括了在SpringBoot项目中添加RabbitMQ的依赖、配置文件设置、启动类注解,以及如何通过单元测试来创建交换器、队列、绑定,并发送和接收消息。文章还介绍了如何配置消息转换器以支持对象的序列化和反序列化,以及如何使用注解`@RabbitListener`来接收消息。
消息中间件RabbitMQ---SpringBoot整合RabbitMQ【三】
|
4月前
|
消息中间件 Docker 容器
消息中间件RabbitMQ---Docker安装RabbitMQ、以及RabbitMQ的基本使用【二】
这篇文章提供了RabbitMQ的安装和基本使用教程,包括如何使用Docker拉取RabbitMQ镜像、创建容器、通过浏览器访问管理界面,以及如何创建交换机、队列、绑定和使用direct、fanout和topic三种类型的交换器进行消息发布和接收的测试。
消息中间件RabbitMQ---Docker安装RabbitMQ、以及RabbitMQ的基本使用【二】