电竞比分网-中国电竞赛事及体育赛事平台

分享

轉:ASP.NET MVC4細嚼慢咽---(6)全局過濾器

 昵稱10504424 2014-09-19

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

Asp.Net MVC4中的全局過濾器,可以對整個項目進行全局監(jiān)控。

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

              表示注冊全局過濾器. 

               GlobalFilters是全局過濾器的集合,可以通過add方法添加過濾器,默認情況下,HandleErrorAttribute過濾器被添加到集合中。

                接下來我們創(chuàng)建一個自定義過濾器,然后添加到全局過濾器集合中。

               1.創(chuàng)建自定義過濾器

                  創(chuàng)建自定義過濾器要繼承ActionFilterAttribute類。我們創(chuàng)建一個名稱為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.注冊全局過濾器

                     過濾器創(chuàng)建完成后,我們把這個過濾器添加到全局過濾器中,使用  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名稱,效果圖如下:

              

標簽: MVC, FilterConfig

 

    本站是提供個人知識管理的網絡存儲空間,所有內容均由用戶發(fā)布,不代表本站觀點。請注意甄別內容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多