Niedawno natknąłem się na log4net dzięki temu użytkownikowi. Tak czy inaczej, chcę zalogować wszystkie pliki Console.Write() i Debug.Write() automatycznie do skonfigurowanego pojedynczego pliku dziennika. Używam również wielu bibliotek klas, które mają również instrukcje Console/Debug, które nie mają pojęcia o log4net. Czy można je również automatycznie logować do pliku dziennika na podstawie konfiguracji? Czy to możliwe?log4net Logging Debug.WriteLine i Console.WriteLine
co chcę rejestrowane w pliku dziennika toczenia:
Console.WriteLine("console statement");
Debug.WriteLine("debug statement");
instancję Rejestrator:
private static readonly ILog log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
private static void InitializeLogger()
{
XmlConfigurator.Configure();
}
Cały app.config:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="SubToolsPortServerTest.log"/>
<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="2" />
<maximumFileSize value="1MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%d [%t] %-5p %c %m%n"/>
</layout>
</appender>
<root>
<level value="ALL" />
<appender-ref ref="LogFileAppender" />
</root>
</log4net>
</configuration>
Joe, akceptuję twoją odpowiedź, ponieważ odpowiada ona na moje pytanie dotyczące wysyłania Debug i Console.WriteLines do log4net. Jednak łatwiej było dodać log4net do każdego projektu i zmienić instrukcje debugowania. Dziękuję Ci. – JMooney
Czy ktoś ma takie blokady? – dmarlow