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
即可。如下