zoukankan      html  css  js  c++  java
  • MVC全局过滤器

    Asp.NET MVC4中的全局过滤器,可以对整个项目进行全局监控。

    新建一个MVC4项目,可以在global.asax文件中看到如下代码:  FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
    表示注册全局过滤器.
    GlobalFilters是全局过滤器的集合,可以通过add方法添加过滤器,默认情况下,HandleErrorAttribute过滤器被添加到集合中。
    接下来我们创建一个自定义过滤器,然后添加到全局过滤器集合中。

    1.创建自定义过滤器
      创建自定义过滤器要继承ActionFilterAttribute类。我们创建一个名称为CustomerFilterAttribute的过滤器,在action里面记录下时间。
        代码如下:
    public class CustomerFilterAttribute : ActionFilterAttribute
            {

                public override void OnActionExecuting(ActionExecutingContext filterContext)
                {
                    base.OnActionExecuting(filterContext);
                    filterContext.HttpContext.Response.Write("开始时间:" + DateTime.Now.ToString() + "<br/>");
                }

                public override void OnActionExecuted(ActionExecutedContext filterContext)
                {
                    base.OnActionExecuted(filterContext);
                    var controllerName = filterContext.RouteData.Values["controller"].ToString();
                    var actionName = filterContext.RouteData.Values["action"].ToString();

                    filterContext.HttpContext.Response.Write("结束时间:" + DateTime.Now.ToString() + "<br/>");
                    filterContext.HttpContext.Response.Write("controller:" + controllerName + ",action:" + actionName);
                }
            }
    2.注册全局过滤器

    过滤器创建完成后,我们把这个过滤器添加到全局过滤器中,使用  filters.Add(new CustomerFilterAttribute());方法,
    代码如下:
     public class FilterConfig
        {
            public static void RegisterGlobalFilters(GlobalFilterCollection filters)
            {
                filters.Add(new HandleErrorAttribute());
                filters.Add(new CustomerFilterAttribute());
            }
        }
    接下来我们运行项目中的每一个页面,都会看到页面中输出时间和controller名称,效果图如下:


    本文内容来源:http://blog.csdn.net/zx13525079024/article/details/19161777

  • 相关阅读:
    随笔
    转:windows 下 netsh 实现 端口映射(端口转发)
    2015年01月01日:新年第一天:happy new year to myself
    谨记一次问题排查经历
    新机器,分区为NTFS, 安装 Windows XP、Windows Server 2003 时蓝屏问题,修改为 FAT32 即可
    Oracle 11g 的bug?: aix 上,expdp 11.2.0.1 导出,impdp 11.2.0.3 导入,Interval 分区的 【Interval】 分区属性成了【N】
    Cursor for loop in Oracle
    Oracle date 详解
    oracle中to_timestamp和to_date什么区别
    Oracle FM FM09999999 确保8位数字 即使全是0
  • 原文地址:https://www.cnblogs.com/zhaow/p/9754170.html
Copyright © 2011-2022 走看看