MVC共有4个过滤器:ActionFilter(方法过滤器),ResultFilter(结果过滤器。感觉是不是很好,所以称它为),AuthorizationFilter(授权过滤器)。ExceptionFilter(异常处理过滤器)
过滤器类型 | 接口 | 默认实现 | 描写叙述 |
Action | IActionFilter | ActionFilterAttribute | 在动作方法之前及之后执行 |
Result | IResultFilter | ActionFilterAttribute | 在动作结果被执行之前和之后执行 |
AuthorizationFilter | IAuthorizationFilter | AuthorizeAttribute | 首先执行,在不论什么其他过滤器动作方法之前执行 |
Exception | IExceptionFilter | HandleErrorAttribute | 仅仅在另外一个过滤器,动作方法,动作结果弹出异常时执行 |
演示样例:Action方法过滤器
/// <summary> /// Action方法 过滤器 类 /// </summary> public class MyActionFilterAttribute : ActionFilterAttribute { /// <summary> /// 在 Action方法之前 调用 /// </summary> /// <param name="filterContext"></param> public override void OnActionExecuting(ActionExecutingContext filterContext) { //1. RouteData 中 保存了 当前请求 匹配的 路由信息和路由对象 // 假设本次请求 是请求了某个 区域 里的 控制器方法,还能够通过filterContext.RouteData.DataTokens["area"]获取区域名 //string strArea = filterContext.RouteData.DataTokens["area"].ToString(); string strController = filterContext.RouteData.Values["controller"].ToString(); string strAction = filterContext.RouteData.Values["action"].ToString(); //filterContext.RouteData.GetRequiredString //2.还有一种方式 获取 请求的 类名和方法名 string strAction2 = filterContext.ActionDescriptor.ActionName; string strController2 = filterContext.ActionDescriptor.ControllerDescriptor.ControllerName; //2.1检查 被请求方法 是否 加了 MoneyAttribute 特性 if (filterContext.ActionDescriptor.IsDefined(typeof(Filters.MoneyAttribute), false)) { //直接为 请求 设置 返回结果。而不运行 相应的 Action 方法,也不运行 OnActionExcuted,可是。会运行 Result过滤器和 生成视图 filterContext.Result = new ContentResult() { Content = "<br/>哈哈哈。直接被跳过了吧~~~!<br/>" }; } filterContext.HttpContext.Response.Write("哇哈哈哈~!OnActionExecuting<br/>"); base.OnActionExecuting(filterContext); } /// <summary> /// 在 Action方法之后 调用 /// </summary> /// <param name="filterContext"></param> public override void OnActionExecuted(ActionExecutedContext filterContext) { filterContext.HttpContext.Response.Write("哇哈哈哈~。OnActionExecuted<br/>"); base.OnActionExecuted(filterContext); }
用法1:将过滤器加到方法上
[Filters.MyActionFilter]//1.将 过滤器 加到方法上 [Filters.Money] [Filters.MyResultFilter] [Filters.MyAuthorize] public ActionResult Index() { Response.Write("Index 方法<br/>"); ViewBag.name = "时间:" + DateTime.Now; return View(); }
用法2:将过滤器加到方类上
[Filters.MyActionFilter] public class HomeController : Controller { }
用法3:加入全局过滤器,即加入到FilterConfig.cs中
public class FilterConfig { public static void RegisterGlobalFilters(GlobalFilterCollection filters) { //filters.Add(new HandleErrorAttribute()); //3. 加入全局过滤器 filters.Add(new Filters.MyActionFilterAttribute()); filters.Add(new Filters.MyHandleErrorAttribute()); } }
演示样例:Result过滤器
/// <summary> /// Result 过滤器 类 - 假设请求的是 要载入视图的 Action 方法的话 /// 在 视图载入 前 后 调用方法 /// </summary> public class MyResultFilterAttribute:System.Web.Mvc.ActionFilterAttribute { /// <summary> /// 载入 "视图" 前运行 /// </summary> /// <param name="filterContext"></param> public override void OnResultExecuting(System.Web.Mvc.ResultExecutingContext filterContext) { filterContext.HttpContext.Response.Write("载入 视图 前运行 OnResultExecuting <br/>"); base.OnResultExecuting(filterContext); } /// <summary> /// 载入"视图" 后运行 /// </summary> /// <param name="filterContext"></param> public override void OnResultExecuted(System.Web.Mvc.ResultExecutedContext filterContext) { filterContext.HttpContext.Response.Write("载入 视图 后运行 OnResultExecuted <br/>"); base.OnResultExecuted(filterContext); } }
演示样例:授权过滤器 - 在 Action过滤器前 运行
/// <summary> /// 授权过滤器 - 在 Action过滤器前 运行 /// </summary> public class MyAuthorizeAttribute:AuthorizeAttribute { public override void OnAuthorization(AuthorizationContext filterContext) { filterContext.HttpContext.Response.Write("<br/>OnAuthorization<br/>"); //凝视掉 父类方法,由于 父类里的 OnAuthorization 方法会 调用 asp.net的授权验证机制! //base.OnAuthorization(filterContext); } }
演示样例:Exception过滤器
/// <summary> /// 异常处理 过滤器 /// </summary> public class MyHandleErrorAttribute : HandleErrorAttribute { 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); } }
版权声明:本文博主原创文章,博客,未经同意不得转载。