设置Log4Net彩色控制台变得简单

时间:2016-08-03 23:22:42

标签: log4net log4net-appender

我正在寻找一个 Log4Net 查看器,我可以在单独的控制台窗口中以实时的形式观看,而不是在Visual Studio输出窗口中,其中包含数百条其他消息

我看到开箱即用的是 ManagedColoredConsoleAppender ColoredConsoleAppender ,但不确定如何将输出定向到外部控制台窗口。理想情况下,调试控制台窗口时会启动,但不是必需的。

我当天使用过 OutputDebugger ,但还没有找到一种方便的方法来完成所有这些工作。

如果有人可以分享如何将所有这些连接起来并快速工作,那将非常感激。

这主要用于本地开发,但如果我们可以将staging和qa中的错误重定向到我机器上的一个漂亮的小窗口,看看实时发生的事情会很好!

1 个答案:

答案 0 :(得分:0)

ColoredConsoleAppender(以及它的后继者ManagedColoredConsoleAppender)不会为你启动一个控制台。

但是,如果您手动启动控制台,他们会使用它 - 这是一个样本:

class Program {

    [DllImport("kernel32.dll", EntryPoint = "GetStdHandle", SetLastError = true, CharSet = CharSet.Auto, CallingConvention = CallingConvention.StdCall)]
    private static extern IntPtr GetStdHandle(int nStdHandle);
    [DllImport("kernel32.dll", EntryPoint = "AllocConsole", SetLastError = true, CharSet = CharSet.Auto, CallingConvention = CallingConvention.StdCall)]
    private static extern int AllocConsole();
    private const int STD_OUTPUT_HANDLE = -11;
    private const int MY_CODE_PAGE = 437;

    private static readonly object lockObj = new object();
    static void Main(string[] args) {

        AllocConsole();
        IntPtr stdHandle = GetStdHandle(STD_OUTPUT_HANDLE);
        SafeFileHandle safeFileHandle = new SafeFileHandle(stdHandle, true);
        FileStream fileStream = new FileStream(safeFileHandle, FileAccess.Write);
        Encoding encoding = Encoding.GetEncoding(MY_CODE_PAGE);
        StreamWriter standardOutput = new StreamWriter(fileStream, encoding) { AutoFlush = true };
        Console.SetOut(standardOutput);

        XmlConfigurator.Configure();

        var log = LogManager.GetLogger("test");
        log.Debug("Starting Program");
        log.Error("Oh no, an error");
        // etc

这是输出:

enter image description here

配置非常简单:

<log4net>
<appender name="ColoredConsoleAppender" type="log4net.Appender.ColoredConsoleAppender">
  <mapping>
    <level value="ERROR" />
    <foreColor value="White" />
    <backColor value="Red, HighIntensity" />
  </mapping>
  <mapping>
    <level value="DEBUG" />
    <backColor value="Green" />
  </mapping>
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
  </layout>
</appender>
<root>
  <level value="DEBUG" />
  <appender-ref ref="ColoredConsoleAppender" />
</root>