不使用xml文件初始化log4net

5
我需要为log4net包创建一个小包装器。同时,我需要在不使用xml配置文件的情况下初始化记录器(这是一个要求,在这个项目中已经有很多配置文件了)。我编写了MyLogger类,但运行程序时控制台上没有任何输出。我试图缩小代码以得到最小的示例(我删除了我的配置文件加载和一些其他内容)。首先我创建日志记录器实例,将级别设置为Trace,然后添加AnsiColorTerminalAppender。显然有什么错误或遗漏,但我无法理解是什么问题。我该如何修复我的类以打印日志消息?
using log4net;

namespace MyProgram
{
  static class MyLogger
  {
    static ILog logger = null;

    public static void SetConfiguration()
    {
      logger = LogManager.GetLogger(typeof(MyLogger));
      var l = (log4net.Repository.Hierarchy.Logger)logger.Logger;
      l.Level = log4net.Core.Level.Trace;
      AddConsoleAppender();
    }

    public static void Debug(string message)
    {
      logger.Debug(message);
    }

    public static void Info(string message)
    {
      logger.Info(message);
    }

    // Others here

    static private void AddConsoleAppender()
    {
      var appender = new log4net.Appender.AnsiColorTerminalAppender
      {
        Threshold = log4net.Core.Level.Info
      };
      var l = (log4net.Repository.Hierarchy.Logger)logger.Logger;
      log4net.Layout.PatternLayout layout = new log4net.Layout.PatternLayout
      {
        ConversionPattern = "%d [%t] %-5p %c [%x] - %m%n"
      };
      layout.ActivateOptions();
      appender.Name = "Console";
      appender.Layout = layout;
      appender.ActivateOptions();
      l.AddAppender(appender);
    }
  }

  class Program
  {
    static void Main(string[] args)
    {
      MyLogger.SetConfiguration();
      MyLogger.Info("Logger configuration loaded");
    }
  }
}
1个回答

4

如果您在不使用BasicConfigurator的情况下添加附加程序,则应手动将Logger存储库的Configured属性设置为true。只需将以下行添加到AddConsoleAppender()方法的底部:

static private void AddConsoleAppender()
{
    // ...
    var l = (log4net.Repository.Hierarchy.Logger)logger.Logger;
    // ...
    l.Repository.Configured = true;
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接