今天大家共同学习下ASP.NET MVC2.0中自定义filters,这一节主要学习下ActionFilterAttribute,

ActionFilterAttribute继承IActionFilter, IResultFilter接口,并且继承FilterAttribute类.

ActionFilterAttribute可以监控action执行过程中所有阶段,包括日志,异常处理等功能.

主要包括以下四个重载方法

OnActionExecuting,OnActionExecuted,OnResultExecuting,OnResultExecuted

1.OnActionExecuting是在action开始前执行

用于身份验证和服务器端缓存输出

2. OnActionExecuted在action结束后执行

主要用于异常处理

3. OnResultExecuting在返回result前执行

主要用于设置客户端缓存和服务器端压缩

4. OnResultExecuted在返回result后执行

主要用于异常处理和页面尾部输出调试信息

以下两个DEMO,将展示actionfilter的具体用法

demo1:

在这个DEMO中我们将展示action在各个阶段的执行时间,并在页面中输出。

首先我们定义一个ActionLogAttribute类

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Web;
  5. using System.Web.Mvc;
  6. namespace MvcAppOne.ActionFilters
  7. {
  8. publicclass ActionLogAttribute : ActionFilterAttribute
  9. {
  10. /// <summary>
  11. /// 表示actionID
  12. /// </summary>
  13. publicint ID
  14. {
  15. get;
  16. set;
  17. }
  18. /// <summary>
  19. /// 在 action开始前执行
  20. /// </summary>
  21. /// <param name="filterContext"></param>
  22. publicoverridevoid OnActionExecuting(ActionExecutingContext filterContext)
  23. {
  24. filterContext.RequestContext.HttpContext.Response.Write(ID.ToString()+":actinon开始执行" + DateTime.Now.ToString() + "<br/>");
  25. base.OnActionExecuting(filterContext);
  26. }
  27. /// <summary>
  28. /// 在action结束后执行
  29. /// </summary>
  30. /// <param name="filterContext"></param>
  31. publicoverridevoid OnActionExecuted(ActionExecutedContext filterContext)
  32. {
  33. filterContext.RequestContext.HttpContext.Response.Write(ID.ToString()+":actinon执行结束" + DateTime.Now.ToString() + "<br/>");
  34. base.OnActionExecuted(filterContext);
  35. }
  36. /// <summary>
  37. /// 在result开始前执行
  38. /// </summary>
  39. /// <param name="filterContext"></param>
  40. publicoverridevoid OnResultExecuting(ResultExecutingContext filterContext)
  41. {
  42. filterContext.RequestContext.HttpContext.Response.Write(ID.ToString()+":result执行开始" + DateTime.Now.ToString() + "<br/>");
  43. base.OnResultExecuting(filterContext);
  44. }
  45. /// <summary>
  46. /// 在result结束后执行
  47. /// </summary>
  48. /// <param name="filterContext"></param>
  49. publicoverridevoid OnResultExecuted(ResultExecutedContext filterContext)
  50. {
  51. filterContext.RequestContext.HttpContext.Response.Write(ID.ToString()+":result执行结束" + DateTime.Now.ToString() + "<br/>");
  52. base.OnResultExecuted(filterContext);
  53. }
  54. }
  55. }
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc; namespace MvcAppOne.ActionFilters
{
public class ActionLogAttribute : ActionFilterAttribute
{
/// <summary>
/// 表示actionID
/// </summary>
public int ID
{
get;
set;
}
/// <summary>
/// 在 action开始前执行
/// </summary>
/// <param name="filterContext"></param>
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
filterContext.RequestContext.HttpContext.Response.Write(ID.ToString()+":actinon开始执行" + DateTime.Now.ToString() + "<br/>");
base.OnActionExecuting(filterContext);
} /// <summary>
/// 在action结束后执行
/// </summary>
/// <param name="filterContext"></param>
public override void OnActionExecuted(ActionExecutedContext filterContext)
{
filterContext.RequestContext.HttpContext.Response.Write(ID.ToString()+":actinon执行结束" + DateTime.Now.ToString() + "<br/>");
base.OnActionExecuted(filterContext);
} /// <summary>
/// 在result开始前执行
/// </summary>
/// <param name="filterContext"></param>
public override void OnResultExecuting(ResultExecutingContext filterContext)
{
filterContext.RequestContext.HttpContext.Response.Write(ID.ToString()+":result执行开始" + DateTime.Now.ToString() + "<br/>");
base.OnResultExecuting(filterContext);
} /// <summary>
/// 在result结束后执行
/// </summary>
/// <param name="filterContext"></param>
public override void OnResultExecuted(ResultExecutedContext filterContext)
{
filterContext.RequestContext.HttpContext.Response.Write(ID.ToString()+":result执行结束" + DateTime.Now.ToString() + "<br/>");
base.OnResultExecuted(filterContext);
} }
}

然后我们建立一个VIEW页面,ShowNews页面

然后再建立一个ACTION,并把属性标记在action上面

  1. [ActionFilters.ActionLog(ID=3)]
  2. public ActionResult ShowNews()
  3. {
  4. return View();
  5. }
 [ActionFilters.ActionLog(ID=3)]
public ActionResult ShowNews()
{
return View();
}

此时我们运行ShowNews页面,我们将看到如下效果

demo2: 接着我们看第二个DEMO,在这个demo中,我们将展现actionFILTER中各个方法的作用

我们建一个类 ActionDealAttribute

  1. publicclass ActionDealAttribute : ActionFilterAttribute
  2. {
  3. publicoverridevoid OnActionExecuting(ActionExecutingContext filterContext)
  4. {
  5. //用户没有验证通过,转向登录页面
  6. if (!filterContext.RequestContext.HttpContext.User.Identity.IsAuthenticated)
  7. {
  8. filterContext.Result = new RedirectResult("../account/logon");
  9. }
  10. }
  11. publicoverridevoid OnActionExecuted(ActionExecutedContext filterContext)
  12. {
  13. //异常处理
  14. if (filterContext.Exception!=null)
  15. {
  16. filterContext.ExceptionHandled=true;
  17. filterContext.Result = new RedirectResult("../shared/Error");//转向错误页面
  18. }
  19. }
  20. publicoverridevoid OnResultExecuting(ResultExecutingContext filterContext)
  21. {
  22. base.OnResultExecuting(filterContext);
  23. }
  24. publicoverridevoid OnResultExecuted(ResultExecutedContext filterContext)
  25. {
  26. base.OnResultExecuted(filterContext);
  27. }
  28. }
public class ActionDealAttribute : ActionFilterAttribute
{
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
//用户没有验证通过,转向登录页面
if (!filterContext.RequestContext.HttpContext.User.Identity.IsAuthenticated)
{
filterContext.Result = new RedirectResult("../account/logon");
}
} public override void OnActionExecuted(ActionExecutedContext filterContext)
{
//异常处理
if (filterContext.Exception!=null)
{
filterContext.ExceptionHandled=true;
filterContext.Result = new RedirectResult("../shared/Error");//转向错误页面
} } public override void OnResultExecuting(ResultExecutingContext filterContext)
{
base.OnResultExecuting(filterContext);
} public override void OnResultExecuted(ResultExecutedContext filterContext)
{
base.OnResultExecuted(filterContext);
} }

再建立一个news页面,并建立一个对应的action

如果访问news页面需要登录才能访问,就在news对应的action标记此属性,在OnActionExecuting中进行处理

  1. [ActionFilters.ActionDeal]
  2. public ActionResult News()
  3. {
  4. return View();
  5. }
[ActionFilters.ActionDeal]
public ActionResult News()
{
return View();
}

如果news页面访问的时候出现异常,就会转向错误页面,在OnActionExecuted中进行处理

  1. [ActionFilters.ActionDeal]
  2. publicvoid News()
  3. {
  4. thrownew Exception();
  5. }
        [ActionFilters.ActionDeal]
public void News()
{
throw new Exception();
}

以上只是自定义action的简单用法,供大家参考。

代码下载:http://download.csdn.net/detail/zx13525079024/4375094

ASP.NET MVC2.0 自定义filters的更多相关文章

  1. ASP.NET MVC2.0学习笔记:路由设置

    Route设置 在 <Professional in ASP.NET MVC2.0>一书的第四章,主要讲述了Route的简单设置.格式化设置.约束设置.区域路由.匹配文件.路由调试以及对R ...

  2. Asp.Net MVC2.0 Url 路由入门---实例篇

    本篇主要讲述Routing组件的作用,以及举几个实例来学习Asp.Net MVC2.0 Url路由技术. 接着上一篇开始讲,我们在Global.asax中注册一条路由后,我们的请求是怎么转到相应的Vi ...

  3. Asp.Net MVC2.0 Url 路由入门---实例篇 【转】

    本篇主要讲述Routing组件的作用,以及举几个实例来学习Asp.Net MVC2.0 Url路由技术. 接着上一篇开始讲,我们在Global.asax中注册一条路由后,我们的请求是怎么转到相应的Vi ...

  4. IIS 6.0上部署ASP.NET MVC2.0

    在IIS7.5及8.0上部署都没有成功,对于身份验证会出现问题,据说是要安装什么东西,在这里说下IIS6.0的配置吧,下面是使用.net 4.0,自己可以选择所需的版本. 再此之前先确定web是用到了 ...

  5. 在iis上部署asp.net mvc2.0

    mvc2.0是vs2010自带的,在开发环境下可以直接部署在iis中.在生产环境下,如果不能找到正确的mvc2.0版本,可以直接把开发环境下的System.Web.Mvc.dll拷贝过去使用. 1,  ...

  6. asp.net MVC2.0学习笔记

    asp.net;与mvc都是不可替代的:只是多一种选择:(解决了许多asp.net的许多缺点) model:充血模型.领域模型:很大程度的封装: 控制器:处理用户的交互,处理业务逻辑的调用,指定具体的 ...

  7. Asp.net MVC4.0自定义Html辅助方法

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.W ...

  8. [ASP.NET MVC2 系列] ASP.Net MVC教程之《在15分钟内用ASP.Net MVC创建一个电影数据库应用程序》

    [ASP.NET MVC2 系列]      [ASP.NET MVC2 系列] ASP.Net MVC教程之<在15分钟内用ASP.Net MVC创建一个电影数据库应用程序>       ...

  9. 经典ASP.NET MVC3.0入门详解

    http://blog.csdn.net/csh624366188/article/details/7064269 :由于本文原在word文档里编写,写本文章时运用了大量截图,直接复制到博客里,没有显 ...

随机推荐

  1. js多个物体运动问题2

    问题1 http://www.cnblogs.com/huaci/p/3854216.html 在上一讲问题1,我们可以整理出2点: 1,定时器作为运动物体的属性 2,startMove方法,参数要传 ...

  2. Ubuntu14.04下安装ZendStudio10.6.1+SVN出现Failed to load JavaHL Library

    Subclipse不能正常工作,打开后报错: Failed to load JavaHL Library. These are the errors that were encountered: no ...

  3. 【C语言探索之旅】 第一部分第六课:条件表达式

    内容简介 1.课程大纲 2.第一部分第六课:条件表达式 3.第一部分第七课预告:循环语句 课程大纲 我们的课程分为四大部分,每一个部分结束后都会有练习题,并会公布答案.还会带大家用C语言编写三个游戏. ...

  4. [精华]Hadoop,HBase分布式集群和solr环境搭建

    1. 机器准备(这里做測试用,目的准备5台CentOS的linux系统) 1.1 准备了2台机器,安装win7系统(64位) 两台windows物理主机: 192.168.131.44 adminis ...

  5. Lua 环境结构 --Linux

    curl -R -O http://www.lua.org/ftp/lua-5.2.3.tar.gz tar zxf lua-5.2.3.tar.gz cd lua-5.2.3 make linux ...

  6. 【浅墨著作】《OpenCV3编程入门》内容简单介绍&amp;勘误&amp;配套源码下载

    经过近一年的沉淀和总结,<OpenCV3编程入门>一书最终和大家见面了. 近期有为数不少的小伙伴们发邮件给浅墨建议最好在博客里面贴出这本书的文件夹,方便大家更好的了解这本书的内容.事实上近 ...

  7. kettle 4.4源代码分析Transformation

    1.1. 相关的类和接口 1.1.1. JobEntryTrans 实现了JobEntryInterface的execute()方法,被job运行.由JobEntryTrans实例化Trans,并运行 ...

  8. React.js入门笔记 创建hello world 的6种方式

    一.ReactJS简介 React 起源于 Facebook 的内部项目,因为该公司对市场上所有 JavaScript MVC 框架,都不满意,就决定自己写一套,用来架设 Instagram 的网站. ...

  9. 高效C++规划

    推荐写C++代码风格.看似easy.坚持不易,且写且珍惜! --陈国林 1. 版本号和版本号声明 版本号和版本号文件声明位于头文件和定义文件的开头,主要内容 (1)版本号信息 (2)文件名.标识符.摘 ...

  10. ActivatedEventArgs.IsApplicationInstancePreserved 属性

    ActivatedEventArgs IsApplicationInstancePreserved 如果 ApplicationInstancePreserved 为 true,则表示该应用程序已休眠 ...