2

我正在使用 Enterprise Library 6 在 ASP.NET MVC 4 Web 应用程序上实现日志记录和用户跟踪。我正在使用 Tracers 来实现这一点,并且我正在将 LogEntries 写入数据库。这很好用,但是现在,我想在 Tracer 条目中添加一些额外的信息,添加到 ExtendedProperties 字段中。我可以在普通的 LogEntry 对象上执行此操作,但我似乎无法在 Tracer 上执行此操作。有什么办法可以做到这一点?

这是我正在做的事情:

using(traceManager.StartTrace(LogCategory.UserTracing.ToString(), activityId))
{
Doit();
}

即使我将 Tracer 分配给一个变量,我也无法对它正在写入的日志条目产生任何影响。我也检查了 TraceManager 类,但它也与此无关。

我想要实现的是以下内容:

LogEntry e = new LogEntry();
e.ExtendedProperties.Add("key", "value");

提前致谢,

罗伯特

4

1 回答 1

2

该类Tracer不公开LogEntry创建的内容,因此无法开箱即用地实现您想要的。

添加扩展属性支持的最简单方法可能是获取源代码Tracer并创建您自己的接受扩展属性的自定义实现。您还可以创建一个TraceManager使用自定义的自定义Tracer

另请注意,开箱即用FormattedDatabaseTraceListener不会记录扩展属性,因此您需要创建一个自定义跟踪侦听器来执行此操作(您可以在Enterprise Library Sample Projects找到一种方法)。

于 2013-10-04T06:24:57.700 回答