利用MVC的自定义过滤器FilterAttribute、IActionFilter、IExceptionFilter实现异常处理等功能

今天在博客园上看了一篇推荐文章,还说得蛮有道理:

http://www.cnblogs.com/richieyang/p/4779028.html

项目中确实有各种后台验证过程,最常见的莫过于判空,而在捕获到了异常信息后如何处理,各个项目组有自己不同的要求。我的项目组要求是:所有业务模块的异常不允许处理,而是直接抛出。

这种统一的处理方式一方面可以简化业务模块的开发过程,即在业务模块中直接throw自定义的异常信息即可,另一方面也可以对异常进行统一的处理,如记录日志等。

上文中也提到在MVC中可以通过ExceptionFilter来进行异常拦截,一下就记录一下MVC中的ExceptionFilter及ActionFilter的用法,其实还有ResultFilter,用于拦截Action执行完毕之后,生成View之前即之后的事件,网上有文章介绍利用ResultFilter实现页面静态化的功能,我没有细看,将来有需要可以研究下。

以下先记录ExceptionFilter及ActionFilter的用法:

1:ExceptionFilter

先定义自己的ExceptionFilter,在这个ExceptionFilter中,记录了异常日志(loggerFactory及logger应该通过IoC容器获取,这里仅作示例),并通过将filterContext.ExceptionHandled置为true来阻止异常抛出,实际上就是把这个异常吞掉了,这里这样处理仅作示例。

public class MyExceptionFilter : FilterAttribute, IExceptionFilter
{
     void IExceptionFilter.OnException(ExceptionContext filterContext)
     {
            var loggerFactory = new Log4NetLoggerFactory("Log4Net.config");
            var logger = loggerFactory.Create();
            logger.Debug("{0}错误信息:", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
            logger.Debug(filterContext.Exception.Message);
            logger.Debug(filterContext.Exception.StackTrace);
            filterContext.ExceptionHandled = true;
      }
}            

定义之后,在需要捕获异常的Action方法上新增[MyExceptionFilter]特性即可。

2:ActionFilter

通过自定义的ActionFilter,拦截Action处理前(OnActionExecuting)及Action处理后(OnActionExecuted)事件,并在事件处理代码中进行日志记录(记录方式仅作演示,实际项目中最好通过IoC容器获取):

        public class MyLoggerFilter : FilterAttribute, IActionFilter
        {
            void IActionFilter.OnActionExecuting(ActionExecutingContext filterContext)
            {
                var loggerFactory = new Log4NetLoggerFactory("Log4Net.config");
                var logger = loggerFactory.Create();
                logger.Debug("{0}-Action开始执行", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
            }

            void IActionFilter.OnActionExecuted(ActionExecutedContext filterContext)
            {
                var user = filterContext.HttpContext.User.Identity.Name;
                var loggerFactory = new Log4NetLoggerFactory("Log4Net.config");
                var logger = loggerFactory.Create();
                logger.Debug("{0}-Action执行完毕", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
            }
        }

在定义了自己的ActionFilter之后,仍然是按需在Action实现上新增[MyLoggerFilter]特性,即可对该Action进行Aop拦截。

时间: 2024-11-06 17:08:35

利用MVC的自定义过滤器FilterAttribute、IActionFilter、IExceptionFilter实现异常处理等功能的相关文章

[转]MVC之 自定义过滤器(Filter)

本文转自:http://www.cnblogs.com/kissdodog/archive/2013/01/21/2869298.html 一.自定义Filter 自定义Filter需要继承ActionFilterAttribute抽象类,重写其中需要的方法,来看下ActionFilterAttribute类的方法签名. //表示所有操作-筛选器特性的基类. [AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, Inh

asp.net MVC之 自定义过滤器(Filter) - shuaixf

一.系统过滤器使用说明 1.OutputCache过滤器 OutputCache过滤器用于缓存你查询结果,这样可以提高用户体验,也可以减少查询次数.它有以下属性: Duration :缓存的时间, 以秒为单位 ,理论上缓存时间可以很长,但实际上当系统资源紧张时,缓存空间还是会被系统收回. VaryByParam :以哪个字段为标识来缓存数据,比如当"ID"字段变化时,需要改变缓存(仍可保留原来的缓存),那么应该设VaryByParam为"ID".这里你可以设置以下几

MVC之 自定义过滤器(Filter)

一.自定义Filter 自定义Filter需要继承ActionFilterAttribute抽象类,重写其中需要的方法,来看下ActionFilterAttribute类的方法签名. //表示所有操作-筛选器特性的基类. [AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, Inherited = true, AllowMultiple = false)] public abstract class ActionFil

MVC系统过滤器、自定义过滤器

一.系统过滤器使用说明 1.OutputCache过滤器 OutputCache过滤器用于缓存你查询结果,这样可以提高用户体验,也可以减少查询次数.它有以下属性: Duration:缓存的时间,以秒为单位,理论上缓存时间可以很长,但实际上当系统资源紧张时,缓存空间还是会被系统收回. VaryByParam:以哪个字段为标识来缓存数据,比如当“ID”字段变化时,需要改变缓存(仍可保留原来的缓存),那么应该设VaryByParam为"ID".这里你可以设置以下几个值: * = 任何参数变化

实现MVC自定义过滤器,自定义Area过滤器,自定义Controller,Action甚至是ViewData过滤器

MVC开发中几种以AOP方式实现的Filters是非常好用的,默认情况下,我们通过App_Start中的FilterConfig来实现的过滤器注册是全局的,也就是整个应用程序都会使用的,针对单独的Filter我们不得不去单独的Controller或者Action去定义 如图: 那么问题来了,我现在想在FitlerConfig里面去维护所有的过滤器,但是又想实现自定义的过滤器该咋搞,MVC默认不支持! 我们先来看看,MVC默认的Fitlers注册是怎样的官方源码:GlobalFilterColle

ASP.NET MVC 如何使用自定义过滤器(筛选器)

原文:ASP.NET MVC 如何使用自定义过滤器(筛选器) 继承*****Attribute(筛选器三种具体类)-->重写方法-->标记在控制器 或者 方法上面 [类名(类属性 = 值)]还有[AllowAnonymous]允许匿名访问(免授权) 原文地址:https://www.cnblogs.com/lonelyxmas/p/10597463.html

ASP.NET MVC 4 (三) 过滤器

先来看看一个例子演示过滤器有什么用: public class AdminController : Controller { // ... instance variables and constructor public ViewResult Index() { if (!Request.IsAuthenticated) { FormsAuthentication.RedirectToLoginPage(); } // ...rest of action method } public Vie

AspNet MVC : 操作/控制器过滤器(action filter)

1.Action Filter Action Filter提供了在执行action/controller前后对请求/响应修改的能力,可以应用于action和控制器上,作用在控制器上将自动被应用到该控制器下所有的action. 常见的应用场景例如: 用户验证授权, 修改view的返回结果,修改response头,日志记录,异常/错误处理等 . AspNet MVC包含四种类型的action filter: a.Auth Filter 验证过滤器,实现IAuthorizationFilter,用于针

ASP.NET MVC学习之过滤器篇(2)

下面我们继续之前的ASP.NET MVC学习之过滤器篇(1)进行学习. 3.动作过滤器 顾名思义,这个过滤器就是在动作方法调用前与调用后响应的.我们可以在调用前更改实际调用的动作,也可以在动作调用完成之后更改最终返回的结果,当然很多人一定不太明白这个到底可以干什么, 下面我们举一个比较实际的例子: 相信理解过网站的安全的一定知道跨站请求(CSRF具体可以自行百度,这里我就不去解释了),当然也有解决方案,那就是给页面中增加一个识别码,当页面进行POST请求时,首先判断识别码是否正确, 如果正确则继