在ASP.NET MVC中有个重要特性就是过滤器,使得我们在MVC程序开发中更好的控制浏览器请求的URL,不是每个请求都有响应内容,只有特定得用户才有。园子里关于过滤器的资料也有很多,这篇文章主要是记录自己的学习。
过滤器类型
类型 | 接口 | 默认实现 | 执行时间 | 描述 |
Action | IActionFilter | ActionFilterAttribute | 用于进入行为之前或之后的处理 | 方法过滤器 |
Result | IResultFilter | ActionFilterAttribute | 用于返回结果的之前或之后的处理 | 结果过滤器 |
Exception | IExceptionFilter |
HandleErrorAttribute |
用于指定一个行为,这个被指定的行为处理某个行为方法或某个控制器里面抛出的异常 | 异常过滤器 |
Authentication | IAuthorizationFilter |
AuthorizeAttribute |
此类型(或过滤器)用于限制进入控制器或控制器的某个行为方法 | 授权过滤器 |
1. Action
- 在ASP.NET MVC项目中新建文件夹Filter,然后再在文件夹下新建类MyActionFilter,在类中添加命名空间using System.Web.Mvc,再继承自ActionFilterAttribute抽象类,我们按F12我们可以看到抽象类有四个方法,从方法的命名我们不难发现他们的执行顺序。
public abstract class ActionFilterAttribute : FilterAttribute, IActionFilter, IResultFilter
{
protected ActionFilterAttribute();
public virtual void OnActionExecuted(ActionExecutedContext filterContext);
public virtual void OnActionExecuting(ActionExecutingContext filterContext);
public virtual void OnResultExecuted(ResultExecutedContext filterContext);
public virtual void OnResultExecuting(ResultExecutingContext filterContext);
}
MyActionFilter.cs
public class MyActionFilter : ActionFilterAttribute
{
public override void OnActionExecuted(ActionExecutedContext filterContext)
{
filterContext.HttpContext.Response.Write("在Action执行后执行");
base.OnActionExecuted(filterContext);
}
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
filterContext.HttpContext.Response.Write("在Action执行前执行");
base.OnActionExecuting(filterContext);
}
}
过滤器可以加在三个地方,第一是控制器上面(可限制控制器下面所有的Action),第二是Action上面(限制指定的Action),第三是全局的过滤器(限制所有的Action)。
- 控制器上面
2. Action上面
3. 全局过滤器
在ASP.NET MVC项目中的App_Start下新建类FilterConfig,添加静态方法RegisterGlobalFilters。
在Global中注册RegisterGlobalFilters方法。
- 运行结果
2. Result
- Result作用于用于返回视图的之前或之后的处理。
代码如下:
//加载试图后执行
public override void OnResultExecuted(ResultExecutedContext filterContext)
{
filterContext.HttpContext.Response.Write("加载视图后执行OnResultExecuted<br/>");
base.OnResultExecuted(filterContext);
}
//加载试图前执行
public override void OnResultExecuting(ResultExecutingContext filterContext)
{
filterContext.HttpContext.Response.Write("加载视图前执行OnResultExecuting<br/>");
base.OnResultExecuting(filterContext);
}
结果如下:
3. Exception
- 异常过滤器最好设置成全局过滤器,记录异常日志。
代码如下:
/// <summary>
/// 异常处理过滤器,最好设置成全局过滤器
/// </summary>
/// <param name="filterContext"></param>
public override void OnException(ExceptionContext filterContext)
{
//1. 获取异常对象
Exception ex = filterContext.Exception;
//2. 记录异常日志
//3. 调整友好页
filterContext.Result = new RedirectResult("~/error.html");
//4. 标记异常已经处理完毕
filterContext.ExceptionHandled = true;
base.OnException(filterContext);
}
4. Authentication
- 授权过滤器作用范围在Action之前
public override void OnAuthorization(AuthorizationContext filterContext)
{
filterContext.HttpContext.Response.Write("授权过滤器");
base.OnAuthorization(filterContext);
}