我正在寻找一个 Log4Net 查看器,我可以在单独的控制台窗口中以实时的形式观看,而不是在Visual Studio输出窗口中,其中包含数百条其他消息
我看到开箱即用的是 ManagedColoredConsoleAppender 和 ColoredConsoleAppender ,但不确定如何将输出定向到外部控制台窗口。理想情况下,调试控制台窗口时会启动,但不是必需的。
我当天使用过 OutputDebugger ,但还没有找到一种方便的方法来完成所有这些工作。
如果有人可以分享如何将所有这些连接起来并快速工作,那将非常感激。
这主要用于本地开发,但如果我们可以将staging和qa中的错误重定向到我机器上的一个漂亮的小窗口,看看实时发生的事情会很好!
答案 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
这是输出:
配置非常简单:
<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>