我是Enterprise Library的新手(5,带有可选更新),我正在尝试将自己的CustomTraceListener与Logging Block一起使用。
日志使用提供的平面文件侦听器,但我似乎无法将其扩展到我的自定义类。
static UnityContainer _container;
static LogWriter _writer;
internal static void Inf(this string message)
{
if (_container == null)
{
_container = new UnityContainer();
_container.AddNewExtension<EnterpriseLibraryCoreExtension>();
}
if (_writer == null && _container != null)
{
_writer = _container.Resolve<LogWriter>();
LogEntry log = new LogEntry();
log.Message = message;
log.Categories.Add("Information");
log.Severity = TraceEventType.Information;
_writer.Write(log);
}
}
namespace Test.Catch
{
[ConfigurationElementType(typeof(CustomTraceListenerData))]
public class LoggerCustom : CustomTraceListener
{
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)
{
Trace.Write(message);
}
public override void WriteLine(string message)
{
Trace.WriteLine(message);
}
}
}
首先我尝试使用配置编辑器添加customtracelistener,但是配置编辑器没有列出/检测任何customtracelisteners,我怀疑它是问题的一部分还是整个问题?
相反,我再次根据bychkov添加了以下内容:
<add listenerDataType="Microsoft.Practices.EnterpriseLibrary.Logging.Configuration.CustomTraceListenerData, Microsoft.Practices.EnterpriseLibrary.Logging, Version=5.0.505.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
type="Test.Catch.LoggerCustom, Test.Catch" traceOutputOptions="None"
name="Custom Trace Listener" initializeData="" formatter="Text Formatter Plain" />
现在,当我调用Inf(“logme”)时,如果包含上面的app.config,则会在_container.AddNewExtension()处抛出异常: 无法解析类型'Test.Catch.LoggerCustom,Test.Catch'。
鉴于我不了解底层机制,我怎样才能使用自定义侦听器进行日志记录?
我是否需要创建自己的TraceListenerData,例如Tavares solution?
或者我是否需要理解和混淆UnityDefaultBehaviorExtension,详见MacLeod?
现有代码是错误的吗?
或解决方案在其他地方?
感谢您的专业知识。
答案 0 :(得分:2)
抓住the Entlib 5 extensibility labs。有关于编写自定义跟踪侦听器的整章。您将学习基础技术,为什么事情按照他们的方式工作,如何组合在一起,然后您就能够回答自己的问题。
至于上述原因不起作用:使用CustomXXXData配置类时,您的提供程序需要一个采用NameValueCollection的构造函数。你没有,所以你的代码实际上是错误的。通过实验室,你将学到更多。