gpt4 book ai didi

log4net - 用于 Log4Net 的 Prism 4 ILoggerFacade?

转载 作者:行者123 更新时间:2023-12-04 02:51:07 25 4
gpt4 key购买 nike

我正在从 Prism 2.1 转换为 Prism 4,我需要为 Log4Net 编写一个 ILoggerFacade 类。我来自 Prism 2.1 的旧代码不再有效。有没有人愿意分享 ILoggerFacade 类的示例代码?谢谢你的帮助。

最佳答案

我想到了。与 Prism 2 非常相似。首先,创建一个实现 ILoggerFacade 的自定义记录器类。这是我的课:

using log4net;
using Microsoft.Practices.Prism.Logging;

namespace FsNoteMaster3
{
class Log4NetLogger : ILoggerFacade
{
#region Fields

// Member variables
private readonly ILog m_Logger = LogManager.GetLogger(typeof(Log4NetLogger));

#endregion

#region ILoggerFacade Members

/// <summary>
/// Writes a log message.
/// </summary>
/// <param name="message">The message to write.</param>
/// <param name="category">The message category.</param>
/// <param name="priority">Not used by Log4Net; pass Priority.None.</param>
public void Log(string message, Category category, Priority priority)
{
switch (category)
{
case Category.Debug:
m_Logger.Debug(message);
break;
case Category.Warn:
m_Logger.Warn(message);
break;
case Category.Exception:
m_Logger.Error(message);
break;
case Category.Info:
m_Logger.Info(message);
break;
}
}

#endregion
}
}

然后,在 Prism 4 Bootstrapper 类中,将覆盖添加到 CreateLogger()返回自定义记录器类的新实例的方法:
protected override Microsoft.Practices.Prism.Logging.ILoggerFacade CreateLogger()
{
return new Log4NetLogger();
}

请注意,在自定义记录器类中, ILog是 Log4Net 接口(interface), LogManager是一个 Log4Net 对象。

从您自己的代码写入自定义记录器(Prism 处理自己的日志条目)与 Prism 2.1 中的稍有不同。您可以直接从 IoC 容器解析记录器,也可以使用 ServiceLocator。 ServiceLocator具有与容器无关的优势,这意味着底层容器并不重要。以下是使用 ServiceLocator 解析记录器的示例:
var logger = (Log4NetLogger)ServiceLocator.Current.GetInstance(typeof(ILoggerFacade));
logger.Log("App.OnStartup() completed", Category.Info ,Priority.None);
ServiceLocator要求宿主项目具有对 Microsoft.Practices.ServiceLocation.dll 的引用和匹配的 using陈述。

关于log4net - 用于 Log4Net 的 Prism 4 ILoggerFacade?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4786222/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com