Welcome 微信登录

首页 / 网页编程 / ASP.NET / Enterprise Library 2.0 Hands On Lab 翻译(5):日志应用程序块(二)

Enterprise Library 2.0 Hands On Lab 翻译(5):日志应用程序块(二)2010-03-02 cnblogs TerryLee练习2:创建并使用自定义的Trace Listener

在本练习中将创建一个自定义的Trace Listener,发送日志项到一个标准的控制台输出,并添加该Trace Listener到EnoughPI应用程序。

第一步

打开EnoughPI.sln项目,默认的安装路径应该为C:Program FilesMicrosoft Enterprise Library January 2006labscsLoggingexercisesex02egin,并编译。

第二步 创建自定义Trace Listener

1.选择项目EnoughPI.Logging,选择Project | Add Reference…菜单命令,添加如下程序集,默认的位置应该为C:Program FilesMicrosoft Enterprise Library January 2006in。

Microsoft.Practices.EnterpriseLibrary.Common.dll

Microsoft.Practices.EnterpriseLibrary.Logging.dll

2.在解决方案管理器中选择TraceListenersConsoleTraceListener.cs文件,单击View | Code菜单命令,添加如下命名空间。

using Microsoft.Practices.EnterpriseLibrary.Common.Configuration;
using Microsoft.Practices.EnterpriseLibrary.Logging;
using Microsoft.Practices.EnterpriseLibrary.Logging.Configuration;
using Microsoft.Practices.EnterpriseLibrary.Logging.Formatters;
using Microsoft.Practices.EnterpriseLibrary.Logging.TraceListeners;

3.添加如下代码到ConsoleTraceListener类中。

[ConfigurationElementType(typeof(CustomTraceListenerData))]
public class ConsoleTraceListener : CustomTraceListener
{
public ConsoleTraceListener()
: base()
{
}
public override void TraceData(TraceEventCache eventCache, string source, TraceEventType eventType, int id, object data)
{
if (data is LogEntry && this.Formatter != null)
{
this.WriteLine(this.Formatter.Format(data as LogEntry));
}
else
{
this.WriteLine(data.ToString());
}
}
public override void Write(string message)
{
Console.Write(message);
}
public override void WriteLine(string message)
{
// Delimit each message
Console.WriteLine((string)this.Attributes["delimiter"]);
// Write formatted message
Console.WriteLine(message);
}
}

注意这里需要继承于基类CustomTraceListener,并且需要覆写基类中的两个抽象方法:Write(string message)和WriteLine(string message),另外由于需要格式化日志信息,还需要覆写TraceData方法。ConsoleTraceListener类有一个参数delimiter,作为Listener配置的一部分。