0

我在 asp.net 中使用 Microsoft Enterprise Library 5.0 进行异常处理。错误存储在系统的事件查看器中。我需要使用企业库将这些错误存储在日志文件(文本文件)中,而不是事件查看器。我该如何实施?

4

2 回答 2

0

你有什么问题?

您基本上必须有一个名为 File 的新接收器,它将日志写入一个平面文件并进行适当的配置。就这样。

是一篇很好的文章,专门用于记录到企业库,尽管有点过时了。

以下是Microsoft 直接提供的示例和动手实验室,其中还包括日志记录示例。

于 2011-11-23T06:38:27.140 回答
0

我假设您对事件日志有这样的配置:

        <add name="Event Log Listener" type="Microsoft.Practices.EnterpriseLibrary.Logging.TraceListeners.FormattedEventLogTraceListener, Microsoft.Practices.EnterpriseLibrary.Logging, Version=5.0.505.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
            listenerDataType="Microsoft.Practices.EnterpriseLibrary.Logging.Configuration.FormattedEventLogTraceListenerData, Microsoft.Practices.EnterpriseLibrary.Logging, Version=5.0.505.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
            source="Enterprise Library Logging" formatter="Text Formatter"
            log="" machineName="." traceOutputOptions="None" />

只需将该配置替换为平面文件即可。例如:

        <add name="Flat File Trace Listener" type="Microsoft.Practices.EnterpriseLibrary.Logging.TraceListeners.FlatFileTraceListener, Microsoft.Practices.EnterpriseLibrary.Logging, Version=5.0.505.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
            listenerDataType="Microsoft.Practices.EnterpriseLibrary.Logging.Configuration.FlatFileTraceListenerData, Microsoft.Practices.EnterpriseLibrary.Logging, Version=5.0.505.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
            fileName="trace.log" />

然后更改您的类别以使用新的“平面文件跟踪侦听器”。如果您使用的不是最新版本,则需要将上述版本从 5.0.505.0 更改为 5.0.414.0。

此外,您可以使用配置工具EntLibConfig.exe来简化这些更改,而无需担心涉及的 XML。或者使用配置工具生成初始 XML,然后您可以在配置文件中手动调整 XML。

或者,作为另一种选择,您可以使用Fluent Configuration API使用代码而不是配置来配置日志记录。

于 2011-11-23T14:57:39.263 回答