惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

F
Fortinet All Blogs
Attack and Defense Labs
Attack and Defense Labs
V2EX - 技术
V2EX - 技术
O
OpenAI News
S
Secure Thoughts
H
Heimdal Security Blog
Application and Cybersecurity Blog
Application and Cybersecurity Blog
Schneier on Security
Schneier on Security
H
Hacker News: Front Page
S
Security Affairs
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Vercel News
Vercel News
Microsoft Security Blog
Microsoft Security Blog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
P
Proofpoint News Feed
The Register - Security
The Register - Security
GbyAI
GbyAI
Cloudbric
Cloudbric
MongoDB | Blog
MongoDB | Blog
D
Darknet – Hacking Tools, Hacker News & Cyber Security
K
Kaspersky official blog
Forbes - Security
Forbes - Security
Y
Y Combinator Blog
C
CXSECURITY Database RSS Feed - CXSecurity.com
Scott Helme
Scott Helme
Hacker News - Newest:
Hacker News - Newest: "LLM"
The Cloudflare Blog
Recorded Future
Recorded Future
人人都是产品经理
人人都是产品经理
Cyberwarzone
Cyberwarzone
C
CERT Recently Published Vulnerability Notes
Webroot Blog
Webroot Blog
C
Cyber Attacks, Cyber Crime and Cyber Security
L
LangChain Blog
T
Tor Project blog
Microsoft Azure Blog
Microsoft Azure Blog
博客园_首页
Hacker News: Ask HN
Hacker News: Ask HN
Blog — PlanetScale
Blog — PlanetScale
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
B
Blog RSS Feed
N
News and Events Feed by Topic
阮一峰的网络日志
阮一峰的网络日志
I
Intezer
V
V2EX
T
Tailwind CSS Blog
SecWiki News
SecWiki News
NISL@THU
NISL@THU
C
Check Point Blog

博客园 - DarroldYang

linux 多线程,锁同步 Saas模式数据库层数据架构以及数据删除处理 ASP.NET MVC 请求生命周期 ASP.NET MVC HtmlHelper类的方法总结 - DarroldYang (Windows 7 IIS 7.5里面的 IIS and Built-in Accounts) IIS和内置帐户的IIS 用户控件,事件的触发顺序 IIS7.0 An ASP.NET setting has been detected that does not apply in Integrated managed pipeline mode 转ORACLE函数大全 ASP.NET AJAX 调用Service Method (Too simply) Office编程知识点汇总(3)--格式设置 Office编程知识点汇总(2)--基本工作表任务 Office编程知识点汇总:基本工作簿任务 asp.NET应用程序的技巧 CrystalReport的导出“Push”方式 Ajax Control Toolkit MutuallyExclusiveCheckBox 服务器端控件 Ajax Control Toolkit Slider 服务器端控件 Ajax Control Toolkit AlwaysVisibleControl 服务器端控件 Ajax Control Toolkit Accordion 服务器端控件 判断代码执行环境
ASP.NET MVC 自定义过滤属性实现Enterprise的log功能
DarroldYang · 2010-04-30 · via 博客园 - DarroldYang

       现在的企业级开发项目,特别是网站一般都会用到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 定义为:

public interface IActionFilter
{
    
// Methods
    void OnActionExecuted(ActionExecutedContext filterContext);
    
void OnActionExecuting(ActionExecutingContext filterContext);
}

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

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

IResultFilter interface定义为:

public interface IResultFilter
{
    
// Methods
    void OnResultExecuted(ResultExecutedContext filterContext);
    
void OnResultExecuting(ResultExecutingContext filterContext);
}

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

接下来是重头戏: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 { getset; }/// <summary>
       
/// 记录时间,系统版本,当前线程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类,应用到Controller或者action的属性。在Controller 正在执行,或者呈现一个View,一个HTTP请求数据时,就会在日志文件记录一些日志.

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

代码

     [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);
     } 

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

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