asp.net core MVC 过滤器之ActionFilter过滤器(二)

简介

Action过滤器将在controller的Action执行之前和之后执行相应的方法。

实现一个自定义Action过滤器

自定义一个全局异常过滤器需要实现IActionFilter接口

public class ActionFilter : IActionFilter

{

    public void OnActionExecuted(ActionExecutedContext context)

    {

        Console.WriteLine("action执行之后");

    }


    public void OnActionExecuting(ActionExecutingContext context)

    {

        Console.WriteLine("action执行之前");

    }

}

IActionFilter需要实现两个方法OnActionExecuted,OnActionExecuting。OnActionExecuting将在Action之前执行,OnActionExecuted在Action之后执行。

知道原理之后我们们就可以利用其特性来简化我们的代码,在MVC中一个重要的概念就时Model验证,我们定义Model约束,然后在Action中验证Model是否绑定成功,我们的Action中重复地写如下代码 

[HttpGet]public ActionResult Get()
{   
 
if (!ModelState.IsValid)
return BadRequest("参数错误!");
}

 这样重复的代码不仅增加代码复杂都也不美观,我们可以在ActionFilter中自动完成

public void OnActionExecuting(ActionExecutingContext context)

{

    if (context.ModelState.IsValid) return;


    var modelState = context.ModelState.FirstOrDefault(f => f.Value.Errors.Any());

    string errorMsg = modelState.Value.Errors.First().ErrorMessage;

    throw new AppException(errorMsg);

}

当Model绑定错误时,我们抛出异常信息,并在上一章节的异常过滤器ExceptionFilter中捕获,返回错误信息给请求方。

我们也可以利用ActionFilter的特性来记录Action的执行时间,当Action执行时间过慢时输出警告日志

 

public class ActionFilter : IActionFilter

{

    public void OnActionExecuted(ActionExecutedContext context)

    {

        var httpContext = context.HttpContext;

        var stopwach = httpContext.Items[Resources.StopwachKey] as Stopwatch;

        stopwach.Stop();

        var time = stopwach.Elapsed;


        if (time.TotalSeconds > 5)

        {

            var factory = context.HttpContext.RequestServices.GetService<ILoggerFactory>();

            var logger = factory.CreateLogger<ActionExecutedContext>();

            logger.LogWarning($"{context.ActionDescriptor.DisplayName}执行耗时:{time.ToString()}");

        }

    }


    public void OnActionExecuting(ActionExecutingContext context)

    {

        var stopwach = new Stopwatch();

        stopwach.Start();

        context.HttpContext.Items.Add(Resources.StopwachKey, stopwach);

    }

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值