ASP.NET MVC2.0 自定义filters
今天大家共同学习下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类
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Web;
- using System.Web.Mvc;
- namespace MvcAppOne.ActionFilters
- {
- publicclass ActionLogAttribute : ActionFilterAttribute
- {
- /// <summary>
- /// 表示actionID
- /// </summary>
- publicint ID
- {
- get;
- set;
- }
- /// <summary>
- /// 在 action开始前执行
- /// </summary>
- /// <param name="filterContext"></param>
- publicoverridevoid 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>
- publicoverridevoid 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>
- publicoverridevoid 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>
- publicoverridevoid OnResultExecuted(ResultExecutedContext filterContext)
- {
- filterContext.RequestContext.HttpContext.Response.Write(ID.ToString()+":result执行结束" + DateTime.Now.ToString() + "<br/>");
- base.OnResultExecuted(filterContext);
- }
- }
- }
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上面
- [ActionFilters.ActionLog(ID=3)]
- public ActionResult ShowNews()
- {
- return View();
- }
[ActionFilters.ActionLog(ID=3)]
public ActionResult ShowNews()
{
return View();
}
此时我们运行ShowNews页面,我们将看到如下效果

demo2: 接着我们看第二个DEMO,在这个demo中,我们将展现actionFILTER中各个方法的作用
我们建一个类 ActionDealAttribute
- publicclass ActionDealAttribute : ActionFilterAttribute
- {
- publicoverridevoid OnActionExecuting(ActionExecutingContext filterContext)
- {
- //用户没有验证通过,转向登录页面
- if (!filterContext.RequestContext.HttpContext.User.Identity.IsAuthenticated)
- {
- filterContext.Result = new RedirectResult("../account/logon");
- }
- }
- publicoverridevoid OnActionExecuted(ActionExecutedContext filterContext)
- {
- //异常处理
- if (filterContext.Exception!=null)
- {
- filterContext.ExceptionHandled=true;
- filterContext.Result = new RedirectResult("../shared/Error");//转向错误页面
- }
- }
- publicoverridevoid OnResultExecuting(ResultExecutingContext filterContext)
- {
- base.OnResultExecuting(filterContext);
- }
- publicoverridevoid OnResultExecuted(ResultExecutedContext filterContext)
- {
- base.OnResultExecuted(filterContext);
- }
- }
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中进行处理
- [ActionFilters.ActionDeal]
- public ActionResult News()
- {
- return View();
- }
[ActionFilters.ActionDeal]
public ActionResult News()
{
return View();
}
如果news页面访问的时候出现异常,就会转向错误页面,在OnActionExecuted中进行处理
- [ActionFilters.ActionDeal]
- publicvoid News()
- {
- thrownew Exception();
- }
[ActionFilters.ActionDeal]
public void News()
{
throw new Exception();
}
以上只是自定义action的简单用法,供大家参考。
代码下载:http://download.csdn.net/detail/zx13525079024/4375094
ASP.NET MVC2.0 自定义filters的更多相关文章
- ASP.NET MVC2.0学习笔记:路由设置
Route设置 在 <Professional in ASP.NET MVC2.0>一书的第四章,主要讲述了Route的简单设置.格式化设置.约束设置.区域路由.匹配文件.路由调试以及对R ...
- Asp.Net MVC2.0 Url 路由入门---实例篇
本篇主要讲述Routing组件的作用,以及举几个实例来学习Asp.Net MVC2.0 Url路由技术. 接着上一篇开始讲,我们在Global.asax中注册一条路由后,我们的请求是怎么转到相应的Vi ...
- Asp.Net MVC2.0 Url 路由入门---实例篇 【转】
本篇主要讲述Routing组件的作用,以及举几个实例来学习Asp.Net MVC2.0 Url路由技术. 接着上一篇开始讲,我们在Global.asax中注册一条路由后,我们的请求是怎么转到相应的Vi ...
- IIS 6.0上部署ASP.NET MVC2.0
在IIS7.5及8.0上部署都没有成功,对于身份验证会出现问题,据说是要安装什么东西,在这里说下IIS6.0的配置吧,下面是使用.net 4.0,自己可以选择所需的版本. 再此之前先确定web是用到了 ...
- 在iis上部署asp.net mvc2.0
mvc2.0是vs2010自带的,在开发环境下可以直接部署在iis中.在生产环境下,如果不能找到正确的mvc2.0版本,可以直接把开发环境下的System.Web.Mvc.dll拷贝过去使用. 1, ...
- asp.net MVC2.0学习笔记
asp.net;与mvc都是不可替代的:只是多一种选择:(解决了许多asp.net的许多缺点) model:充血模型.领域模型:很大程度的封装: 控制器:处理用户的交互,处理业务逻辑的调用,指定具体的 ...
- Asp.net MVC4.0自定义Html辅助方法
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.W ...
- [ASP.NET MVC2 系列] ASP.Net MVC教程之《在15分钟内用ASP.Net MVC创建一个电影数据库应用程序》
[ASP.NET MVC2 系列] [ASP.NET MVC2 系列] ASP.Net MVC教程之<在15分钟内用ASP.Net MVC创建一个电影数据库应用程序> ...
- 经典ASP.NET MVC3.0入门详解
http://blog.csdn.net/csh624366188/article/details/7064269 :由于本文原在word文档里编写,写本文章时运用了大量截图,直接复制到博客里,没有显 ...
随机推荐
- win7/win8通过媒体流(DLNA技术)共享音乐照片和视频
http://www.jb51.net/os/windows/79421.html 工具/原料 Windows 7/8/10家庭高级版以上版本 家庭WiFi局域网(无须连接互联网) 支持DLNA的手机 ...
- 用Linux/Unix命令把十六进制转换成十进制(转)
那天写个脚本,需要把十六进制的数字转成十进制的打出来,发现不知道要怎么弄,搜一下,原来还是很简单的,比用C语言什么的容易多了,就一些现成的命令就解决了. 先列两种简单的方法: 1) echo 自己就能 ...
- Spring HTTPInvoker原理猜想(HTTP+序列化)
没有查看源码,仅作参考 实现步骤: 一,客户端 (1),远程调用信息封装为远程调用对象 (2),序列化写入到远程调用HTTP请求中 (3),向服务器发送 (4),服务器端返回的HTTP响应结果 (5) ...
- ABP-N层架构
ABP理论学习之N层架构 返回总目录 自从写这个系列博客之后,发现很多园友还是希望有个直接运行的demo,其实在github上就有官方的demo,我直接把这demo的链接放到这里吧,另外,我分析, ...
- 高榕资本宾悦:未使用的企业家Testin云测试服务类故障
高榕资本岳斌:创业者未使用Testin云測试服务属不合格 2014/10/09 · Testin · 开发人员訪谈 Testin云測与工信部等联合承办的ICT中国.2014高层论坛之移动开发人员分论坛 ...
- 对SA权限的再突破 (对付xplog70.dll被删)转载
原文:对SA权限的再突破 (对付xplog70.dll被删)转载 对SA权限的再突破 (对付xplog70.dll被删)转载 转载自:http://www.bitscn.com/plus/view.p ...
- C++学习笔记25,析构函数总是会宣布virtual
为了永远记住析构函数声明virtual----><<effective c++>> 为这句话不一定对,但无需质疑的是这句话是非常实用的. 查看以下的样例: #includ ...
- Duanxx的Altium Designer学习:PCB试想一下,在目前的水平
1 Shift+S 这个快捷键能高亮当前层,而且使其它层变成灰色.见下图: 2 隐藏指定层 在图中右下角的地方,右键.会弹出一个选项条.选择Hide Layers.能够选择想要隐藏的 ...
- DBA工具——DMV——如何知道TSQL语句已运行了多久
原文:DBA工具--DMV--如何知道TSQL语句已运行了多久 DBA通常想知道正在运行的语句已经执行了多久了?可以使用Sqlserver profiler来捕获语句的开始时间,和现有时间比较,但是在 ...
- Sonar Qube QA
配置:1.配置环境变量 SONAR_RUNNER_HOME2.配置path :增加%SONAR_RUNNER_HOME%\bin3.在自己的本地项目的根目录下创建 sonar-project.pro ...