ASP.NETMVC自定义过滤属性实现log功能

向您推荐《ASP.NET MVC框架视频教程》,希望通过本教程能让大家更好的理解ASP.NET MVC。

创新互联专注于东丰企业网站建设,响应式网站建设,商城网站建设。东丰网站建设公司,为东丰等地区提供建站服务。全流程定制制作,专业设计,全程项目跟踪,创新互联专业和态度为您提供的服务

现在的企业级开发项目,特别是网站一般都会用到log功能,想想大部分会用Enterprise Logging Application Block 的功能 或者自己写一个组件,记录系统日志事件,更好的跟踪了解系统运行情况, 现用ASP.NET MVC 的过滤属性实现log功能!

ASP.NET MVC的filter 是一个属性,可以应用到controller 后者action.当Controller或者action method 被调用时,ASP.NET MVC的filter在调用执行前后会被触发。 先看下当Control 里面的action 被调用时的利用继承,自定义类log的效果图:

要实现上面的效果,现自定义一个类LogMessageAttribute,LogMessageAttribute继承接口IActionFilter ,IResultFilter,也可以选择性的继承重写类FilterAttribute。

IActionFilter interface 定义为:

 
 
 
 
  1. public interface IActionFilter  
  2. {  
  3.     // Methods  
  4.     void OnActionExecuted(ActionExecutedContext filterContext);  
  5.     void OnActionExecuting(ActionExecutingContext filterContext);  

OnActionExecuting :在Controller 里面的action method 调用之前运行

OnActionExecuted:在Controller 里面的action method 调用之后运行,但是在IResultFilter接口的OnResultExecuting方法执行之前

IResultFilter interface定义为:

 
 
 
 
  1. public interface IResultFilter  
  2. {  
  3.     // Methods  
  4.     void OnResultExecuted(ResultExecutedContext filterContext);  
  5.     void OnResultExecuting(ResultExecutingContext filterContext);  

OnResultExecuting:在Controller 里面的action method调用处理玩前执行.
OnResultExecuted:在Controller 里面的action method调用处理玩后执行.

接下来是重头戏:LogMessageAttribute自定义类

 
 
 
 
  1. [AttributeUsage(AttributeTargets.Class |AttributeTargets.Method ,Inherited=true ,AllowMultiple=true )]  
  2.     public class LogMessageAttribute:FilterAttribute,IActionFilter,IResultFilter   
  3.     {     
  4.         ///   
  5.         /// 日志文件路径  
  6.         ///   
  7.         public string LogName { get; set; }  
  8.  
  9.    
  10.  
  11.        ///   
  12.        /// 记录时间,系统版本,当前线程ID 等记录  
  13.        ///   
  14.        ///   
  15.        ///   
  16.        ///   
  17.         public void LogMessage(string controller, string action, string message)  
  18.         {  
  19.             if (!string.IsNullOrEmpty(LogName))  
  20.             {  
  21.                   
  22.  
  23.                TextWriter writer = new StreamWriter(LogName, true);  
  24.                writer.WriteLine("################# Begin #################");  
  25.                writer.WriteLine("Time:[{0}]",DateTime.Now.ToString("yyyy-MM-dd- hh:mm:ss"));  
  26.                writer.WriteLine("Controller:{0}",controller);  
  27.                writer.WriteLine("Action:{0}",action);  
  28.                writer.WriteLine("Message:{0}",message);  
  29.                writer.WriteLine("Operating System version is:{0}",System.Environment.OSVersion.Version.ToString());  
  30.                writer.WriteLine("Current Thread ID is:{0}",AppDomain.GetCurrentThreadId());  
  31.                writer.WriteLine("############### Over ###############");  
  32.                writer.Close();   
  33.  
  34.             }  
  35.         }  
  36.         public void OnActionExecuting(ActionExecutingContext filterContext)  
  37.         {  
  38.             LogMessage(filterContext.RouteData.Values["controller"].ToString(),  
  39.                 filterContext.RouteData.Values["action"].ToString(),  
  40.                 "Action exeuting...");  
  41.         }  
  42.         public void OnActionExecuted(ActionExecutedContext filterContext)  
  43.         {  
  44.             LogMessage(filterContext.RouteData.Values["controller"].ToString(),  
  45.                 filterContext.RouteData.Values["action"].ToString(),  
  46.                 "Action executed.");  
  47.         }  
  48.         public void OnResultExecuting(ResultExecutingContext filterContext)  
  49.         {  
  50.             LogMessage(filterContext.RouteData.Values["controller"].ToString(),  
  51.                 filterContext.RouteData.Values["action"].ToString(),  
  52.                 "Result executing...");  
  53.         }  
  54.         public void OnResultExecuted(ResultExecutedContext filterContext)  
  55.         {  
  56.             LogMessage(filterContext.RouteData.Values["controller"].ToString(),  
  57.                   filterContext.RouteData.Values["action"].ToString(),  
  58.                   "Result executed");  
  59.         }  
  60.     }  

自定义好LogMessageAttribute类,应用到Controller或者action的属性。在Controller 正在执行,或者呈现一个View,一个HTTP请求数据时,就会在日志文件记录一些日志.

在项目的Controller里面应用自定义的属性

 
 
 
 
  1. [Logging(LogName = @"D:\Project\Project\MVCProject\sky.ExtendMVCFramework\sky.ExtendMVCFramework\Log.log")]  
  2.      public ActionResult DesplayEmployee()  
  3.      {  
  4.          ViewData["Message"] = "Our employees welcome you to our site!";  
  5.          List employees = new List  
  6.           {  
  7.               new Employee {  
  8.                   FirstName="sky",  
  9.                   LastName="yang",  
  10.                   Email = "weflytotti@163.com",  
  11.                   Department ="Development" 
  12.               },  
  13.               new Employee {  
  14.                   FirstName="sky",  
  15.                   LastName="yang",  
  16.                   Email = "weflytotti@163.com",  
  17.                   Department ="Development" 
  18.               }  
  19.           };  
  20.          return View(employees);  
  21.      }  

运行程序,正如文章开始所看到的截图!

总结:自定义ASP.NET MVC 的过滤属性实现自己想要的功能只需要继承IActionFilter ,IResultFilter。

分享名称:ASP.NETMVC自定义过滤属性实现log功能
当前网址:http://www.shufengxianlan.com/qtweb/news27/98377.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联