Asp.Net MVC4中的全局過濾器

能夠對整個項目進行全局監控。ide

              新建一個MVC4項目,能夠在global.asax文件中看到以下代碼:  FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);blog

              表示註冊全局過濾器. 繼承

               GlobalFilters是全局過濾器的集合,能夠經過add方法添加過濾器,默認狀況下,HandleErrorAttribute過濾器被添加到集合中。it

                接下來咱們建立一個自定義過濾器,而後添加到全局過濾器集合中。io

               1.建立自定義過濾器class

                  建立自定義過濾器要繼承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.註冊全局過濾器im

                     過濾器建立完成後,咱們把這個過濾器添加到全局過濾器中,使用  filters.Add(new CustomerFilterAttribute());方法,d3

                       代碼以下:

public class FilterConfig  
   {  
       public static void RegisterGlobalFilters(GlobalFilterCollection filters)  
       {  
           filters.Add(new HandleErrorAttribute());  
           filters.Add(new CustomerFilterAttribute());  
       }  
   }  

    接下來咱們運行項目中的每個頁面,都會看到頁面中輸出時間和controller名稱,效果圖以下:

                                

相關文章
相關標籤/搜索