程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> 關於ASP.NET >> Enterprise Library 2.0 Hands On Lab 翻譯(5):日志應用程序塊(二)

Enterprise Library 2.0 Hands On Lab 翻譯(5):日志應用程序塊(二)

編輯:關於ASP.NET

練習2:創建並使用自定義的Trace Listener

在本練習中將創建一個自定義的Trace Listener,發送日志項到一個標准的控制台輸出,並添加該Trace Listener到EnoughPI應用程序。

第一步

打開EnoughPI.sln項目,默認的安裝路徑應該為C:\Program Files\Microsoft Enterprise Library January 2006\labs\cs\Logging\exercises\ex02\begin,並編譯。

第二步 創建自定義Trace Listener

1.選擇項目EnoughPI.Logging,選擇Project | Add Reference…菜單命令,添加如下程序集,默認的位置應該為C:\Program Files\Microsoft Enterprise Library January 2006\bin。

Microsoft.Practices.EnterpriseLibrary.Common.dll

Microsoft.Practices.EnterpriseLibrary.Logging.dll

2.在解決方案管理器中選擇TraceListeners\ConsoleTraceListener.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配置的一部分。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved