ASP.NET MVC自定義過濾屬性實(shí)現(xiàn)log功能
51CTO向您推薦《ASP.NET MVC框架視頻教程》,希望通過本教程能讓大家更好的理解ASP.NET MVC。
現(xiàn)在的企業(yè)級(jí)開發(fā)項(xiàng)目,特別是網(wǎng)站一般都會(huì)用到log功能,想想大部分會(huì)用Enterprise Logging Application Block 的功能 或者自己寫一個(gè)組件,記錄系統(tǒng)日志事件,更好的跟蹤了解系統(tǒng)運(yùn)行情況, 現(xiàn)用ASP.NET MVC 的過濾屬性實(shí)現(xiàn)log功能!
ASP.NET MVC的filter 是一個(gè)屬性,可以應(yīng)用到controller 后者action.當(dāng)Controller或者action method 被調(diào)用時(shí),ASP.NET MVC的filter在調(diào)用執(zhí)行前后會(huì)被觸發(fā)。 先看下當(dāng)Control 里面的action 被調(diào)用時(shí)的利用繼承,自定義類log的效果圖:
要實(shí)現(xiàn)上面的效果,現(xiàn)自定義一個(gè)類LogMessageAttribute,LogMessageAttribute繼承接口IActionFilter ,IResultFilter,也可以選擇性的繼承重寫類FilterAttribute。
IActionFilter interface 定義為:
- public interface IActionFilter
- {
- // Methods
- void OnActionExecuted(ActionExecutedContext filterContext);
- void OnActionExecuting(ActionExecutingContext filterContext);
- }
OnActionExecuting :在Controller 里面的action method 調(diào)用之前運(yùn)行
OnActionExecuted:在Controller 里面的action method 調(diào)用之后運(yùn)行,但是在IResultFilter接口的OnResultExecuting方法執(zhí)行之前
IResultFilter interface定義為:
- public interface IResultFilter
- {
- // Methods
- void OnResultExecuted(ResultExecutedContext filterContext);
- void OnResultExecuting(ResultExecutingContext filterContext);
- }
OnResultExecuting:在Controller 里面的action method調(diào)用處理玩前執(zhí)行.
OnResultExecuted:在Controller 里面的action method調(diào)用處理玩后執(zhí)行.
接下來(lái)是重頭戲:LogMessageAttribute自定義類
- [AttributeUsage(AttributeTargets.Class |AttributeTargets.Method ,Inherited=true ,AllowMultiple=true )]
- public class LogMessageAttribute:FilterAttribute,IActionFilter,IResultFilter
- {
- /// <summary>
- /// <param name="LogName ">日志文件路徑</para>
- /// </summary>
- public string LogName { get; set; }
- /// <summary>
- /// 記錄時(shí)間,系統(tǒng)版本,當(dāng)前線程ID 等記錄
- /// </summary>
- /// <param name="controller"></param>
- /// <param name="action"></param>
- /// <param name="message"></param>
- public void LogMessage(string controller, string action, string message)
- {
- if (!string.IsNullOrEmpty(LogName))
- {
- TextWriter writer = new StreamWriter(LogName, true);
- writer.WriteLine("################# Begin #################");
- writer.WriteLine("Time:[{0}]",DateTime.Now.ToString("yyyy-MM-dd- hh:mm:ss"));
- writer.WriteLine("Controller:{0}",controller);
- writer.WriteLine("Action:{0}",action);
- writer.WriteLine("Message:{0}",message);
- writer.WriteLine("Operating System version is:{0}",System.Environment.OSVersion.Version.ToString());
- writer.WriteLine("Current Thread ID is:{0}",AppDomain.GetCurrentThreadId());
- writer.WriteLine("############### Over ###############");
- writer.Close();
- }
- }
- public void OnActionExecuting(ActionExecutingContext filterContext)
- {
- LogMessage(filterContext.RouteData.Values["controller"].ToString(),
- filterContext.RouteData.Values["action"].ToString(),
- "Action exeuting...");
- }
- public void OnActionExecuted(ActionExecutedContext filterContext)
- {
- LogMessage(filterContext.RouteData.Values["controller"].ToString(),
- filterContext.RouteData.Values["action"].ToString(),
- "Action executed.");
- }
- public void OnResultExecuting(ResultExecutingContext filterContext)
- {
- LogMessage(filterContext.RouteData.Values["controller"].ToString(),
- filterContext.RouteData.Values["action"].ToString(),
- "Result executing...");
- }
- public void OnResultExecuted(ResultExecutedContext filterContext)
- {
- LogMessage(filterContext.RouteData.Values["controller"].ToString(),
- filterContext.RouteData.Values["action"].ToString(),
- "Result executed");
- }
- }
自定義好LogMessageAttribute類,應(yīng)用到Controller或者action的屬性。在Controller 正在執(zhí)行,或者呈現(xiàn)一個(gè)View,一個(gè)HTTP請(qǐng)求數(shù)據(jù)時(shí),就會(huì)在日志文件記錄一些日志.
在項(xiàng)目的Controller里面應(yīng)用自定義的屬性
- [Logging(LogName = @"D:\Project\Project\MVCProject\sky.ExtendMVCFramework\sky.ExtendMVCFramework\Log.log")]
- public ActionResult DesplayEmployee()
- {
- ViewData["Message"] = "Our employees welcome you to our site!";
- List<Employee> employees = new List<Employee>
- {
- new Employee {
- FirstName="sky",
- LastName="yang",
- Email = "weflytotti@163.com",
- Department ="Development"
- },
- new Employee {
- FirstName="sky",
- LastName="yang",
- Email = "weflytotti@163.com",
- Department ="Development"
- }
- };
- return View(employees);
- }
運(yùn)行程序,正如文章開始所看到的截圖!
總結(jié):自定義ASP.NET MVC 的過濾屬性實(shí)現(xiàn)自己想要的功能只需要繼承IActionFilter ,IResultFilter。
原文標(biāo)題:ASP.NET MVC 自定義過濾屬性實(shí)現(xiàn)Enterprise的log功能
鏈接:http://www.cnblogs.com/skyyang/archive/2010/04/30/1724580.html
【編輯推薦】