• 转:ASP.NET MVC4细嚼慢咽---(6)全局过滤器


     原文:http://blog.csdn.net/zx13525079024/article/details/19161777

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

                  新建一个MVC4项目,可以在global.asax文件中看到如下代码:  FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);

                  表示注册全局过滤器. 

                   GlobalFilters是全局过滤器的集合,可以通过add方法添加过滤器,默认情况下,HandleErrorAttribute过滤器被添加到集合中。

                    接下来我们创建一个自定义过滤器,然后添加到全局过滤器集合中。

                   1.创建自定义过滤器

                      创建自定义过滤器要继承ActionFilterAttribute类。我们创建一个名称为CustomerFilterAttribute的过滤器,在action里面记录下时间。

                        代码如下:

                      

    [csharp] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. public class CustomerFilterAttribute : ActionFilterAttribute  
    2.   {  
    3.   
    4.       public override void OnActionExecuting(ActionExecutingContext filterContext)  
    5.       {  
    6.           base.OnActionExecuting(filterContext);  
    7.           filterContext.HttpContext.Response.Write("开始时间:"+DateTime.Now.ToString()+"<br/>");  
    8.       }  
    9.   
    10.       public override void OnActionExecuted(ActionExecutedContext filterContext)  
    11.       {  
    12.           base.OnActionExecuted(filterContext);  
    13.           var controllerName = filterContext.RouteData.Values["controller"].ToString();  
    14.           var actionName = filterContext.RouteData.Values["action"].ToString();  
    15.   
    16.           filterContext.HttpContext.Response.Write("结束时间:" + DateTime.Now.ToString() + "<br/>");  
    17.           filterContext.HttpContext.Response.Write("controller:" +controllerName+",action:"+actionName);  
    18.       }  
    19.   }  

                   2.注册全局过滤器

                         过滤器创建完成后,我们把这个过滤器添加到全局过滤器中,使用  filters.Add(new CustomerFilterAttribute());方法,

                           代码如下:

                         

    [csharp] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. public class FilterConfig  
    2.    {  
    3.        public static void RegisterGlobalFilters(GlobalFilterCollection filters)  
    4.        {  
    5.            filters.Add(new HandleErrorAttribute());  
    6.            filters.Add(new CustomerFilterAttribute());  
    7.        }  
    8.    }  

              接下来我们运行项目中的每一个页面,都会看到页面中输出时间和controller名称,效果图如下:

                  

  • 相关阅读:
    2017《Java技术》预备作业 计科1501 杨柳
    Java技术预备作业02 计科1501杨柳
    H2O.ai初步使用
    Vue.Js加入bootstrap及jquery,或加入其他插件vueresource,vuex等
    初次使用git上传代码(转)
    svg绘图工具raphael.js的使用
    EF6添加mysql的edmx实体时报错:无法生成模型:“System.Data.StrongTypingException: 表“TableDetails”中列“IsPrimaryKey”的值为 DBNull
    在window下搭建Vue.Js开发环境
    SQL Server: 索引碎片产生及修复
    Windows注册表(regedit.exe)
  • 原文地址:https://www.cnblogs.com/ookami/p/3976510.html
Copyright © 2020-2023  润新知