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