在控制器的方法(action)执行前和执行后,action过滤器都会被执行。
下面以WebApi项目为例,记录action过滤器的使用方法。
如果有多个action过滤器,那么他们的执行顺序如下所示,每个action过滤器都会被执行两次,分别是在action执行前和执行后各被执行一次。
下面通过项目来展示action过滤器的具体使用:
1.新建一个WebApi项目,在模板控制器中添加输出信息,方便观察过滤器的执行情况。
2.自定义类MyActionFilter,实现接口IAsyncActionFilter。
using Microsoft.AspNetCore.Mvc.Filters;
using System;
using System.Threading.Tasks;
namespace WebApiActionFilter
{
public class MyActionFilter : IAsyncActionFilter
{
public async Task OnActionExecutionAsync(ActionExecutingContext context, ActionExecutionDelegate next)
{
Console.WriteLine("MyActionFilter 执行action前");
var result = await next();
if (result.Exception!=null)
{
Console.WriteLine("MyActionFilter 发生异常");
}
else
{
Console.WriteLine("MyActionFilter 执行action后");
}
}
}
}
3.将自定义的过滤器进行注入。
运行项目,访问控制器的action方法:
可以看到在action 执行前后分别输出了打印信息。
同时可以执行多个自定义的action过滤器,例如,在上面的基础上,增加一个action过滤器。
创建MyActionFilter2过滤器类,实现IAsyncActionFilter接口。
using Microsoft.AspNetCore.Mvc.Filters;
using System;
using System.Threading.Tasks;
namespace WebApiActionFilter
{
public class MyActionFilter2 : IAsyncActionFilter
{
public async Task OnActionExecutionAsync(ActionExecutingContext context, ActionExecutionDelegate next)
{
Console.WriteLine("MyActionFilter2 执行action前");
var result = await next();
if (result.Exception!=null)
{
Console.WriteLine("MyActionFilter2 发生异常");
}
else
{
Console.WriteLine("MyActionFilter2 执行action后");
}
}
}
}
将新加的过滤器注入到服务中
运行项目
通过输出的信息,可以看到程序的执行顺序和开头图片中展示的执行顺序是一样的,先执行过滤器中next()方法前面部分代码,然后执行action方法,最后再分别执行next()方法后面部分的代码。