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

设置Log4Net彩色控制台使操作变得简单,log4net,log4net-appender,Log4net,Log4net Appender,我正在寻找一个Log4Net查看器,我可以在realtime中在一个单独的控制台窗口中观看,而不是在Visual Studio输出窗口中观看,该窗口混合了数百条其他消息 我看到有一个现成的ManagedColoredConsolePender和ColoredConsolePender,但不确定如何将输出定向到外部控制台窗口。理想情况下,调试控制台窗口时会启动,但不是一项要求 我曾经使用过OutputDebugger,但还没有找到一种简单的方法来让所有这些工作正常进行 如果有人能分享如何将所有这些

我正在寻找一个Log4Net查看器,我可以在realtime中在一个单独的控制台窗口中观看,而不是在Visual Studio输出窗口中观看,该窗口混合了数百条其他消息

我看到有一个现成的ManagedColoredConsolePenderColoredConsolePender,但不确定如何将输出定向到外部控制台窗口。理想情况下,调试控制台窗口时会启动,但不是一项要求

我曾经使用过OutputDebugger,但还没有找到一种简单的方法来让所有这些工作正常进行

如果有人能分享如何将所有这些连接起来并快速工作,我们将不胜感激


这将主要用于本地开发,但如果我们能够将错误从暂存和qa重定向到我机器上的一个漂亮的小窗口,以实时查看发生了什么,那就太好了

ColoredConsolePender(及其继任者ManagedColoredConsolePender)不会为您启动控制台

但是,如果您手动启动控制台,他们将使用它-以下是一个示例:

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
这是输出:

配置非常简单:

<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>


只有ManagedColoredConsolleAppender对我有效,.net 4.7.2