Microsoft.AspNetCore.Mvc.Filters

Filter的作用是在Action 执行前或执行后做一些加工处理。会跟Middleware很像,但执行的顺序略有不同,用对Filter不仅可以减少代码,还可以提高执行效率。

横切关注点(cross-cutting concerns)

Authorization Filter:优先级最高的,通常用于验证Request合不合法,不合法后面就直接跳过

Resource Filter :第二优先,会在Authorization之后,Model Binding之前执行。通常会是需要对Model加工处理才用。

Action Filter:最常使用的Filter,封包进出都会经过它,使用上没什么需要特别注意的。跟Resource Filter很类似,但并不会经过Model Binding。

Result Filter:当Action完成后,最终会经过的Filter。

 

  • 黄色箭头是正常情况流程
  • 灰色箭头是异常处理流程

1、建立Filter

2、Filter有两种注册方式,一种是全局注册,另一种是用[Attribute]局部注册的方式,只套用在特定的Controller或Action

 全局注册:在Startup.ConfigureServices的MVC服务中注册Filter,这样就可以套用到所有的Request

 局部注册:ASP.NET Core在局部注册Filter的方式跟ASP.NET MVC有一点不一样,要通过[TypeFilter(type)]

[TypeFilter(type)]用起来有点冗长,想要像过去ASP.NET MVC用[Attribute]注册Filter的话,只要将Filter继承Attribute即可。如下

 

posted on   dollymi  阅读(987)  评论(0编辑  收藏  举报

编辑推荐:
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
阅读排行:
· 互联网不景气了那就玩玩嵌入式吧,用纯.NET开发并制作一个智能桌面机器人(四):结合BotSharp
· 软件产品开发中常见的10个问题及处理方法
· Vite CVE-2025-30208 安全漏洞
· MQ 如何保证数据一致性?
· 《HelloGitHub》第 108 期
点击右上角即可分享
微信分享提示