C# Winform使用log4net進(jìn)行日志記錄
寫(xiě)在前面
Log4Net是從Java的log4j移植過(guò)來(lái)的,功能也與log4j類(lèi)似,可以把日志信息輸出到文件、數(shù)據(jù)庫(kù)、控制臺(tái)、Windows 事件日志、遠(yuǎn)程系統(tǒng)日志服務(wù)等不同的介質(zhì)或目標(biāo)。
Log4Net配置選項(xiàng)豐富靈活,并且可在運(yùn)行時(shí)動(dòng)態(tài)更新配置并應(yīng)用,允許同時(shí)推送到多個(gè)目標(biāo);雖然項(xiàng)目已經(jīng)休眠了,但是該類(lèi)庫(kù)已久經(jīng)考驗(yàn),經(jīng)典的設(shè)計(jì)永不過(guò)時(shí)。
獲取類(lèi)庫(kù)
可通過(guò)NuGet獲取類(lèi)庫(kù),引入到項(xiàng)目中。

配置模板
新建log4net.xml文件,命名成log4net.config也可以,初始化時(shí)保持一致即可,配置內(nèi)容如下:
<?xml version="1.0" encoding="utf-8"?>
<log4net>
<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger %ndc - %message%newline" />
</layout>
</appender>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="INFO">
<!--防止多線(xiàn)程時(shí)不能寫(xiě)Log,官方說(shuō)線(xiàn)程非安全-->
<param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
<param name="File" value="Logs/" />
<param name="AppendToFile" value="true"/>
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyy-MM-dd.'info.log'" />
<param name="RollingStyle" value="Date"/>
<param name="MaxSizeRollBackups" value="10" />
<param name="MaximumFileSize" value="5MB" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="## %d [%t] %-5p %x %m %n"/>
<!--<param name="ConversionPattern" value="%date [%thread] %-5level [%logger] %ndc - %message%newline" />-->
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="INFO" />
<param name="LevelMax" value="INFO" />
</filter>
</appender>
<appender name="ErrorFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="ERROR">
<param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
<param name="File" value="Logs/" />
<param name="AppendToFile" value="true"/>
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyy-MM-dd.'error.log'" />
<param name="RollingStyle" value="Date"/>
<param name="MaxSizeRollBackups" value="10" />
<param name="MaximumFileSize" value="5MB" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%date [%thread] %-5level [%logger] %ndc - %message%newline" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="WARN" />
<param name="LevelMax" value="ERROR" />
</filter>
</appender>
<appender name="DebugFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="ERROR">
<param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
<param name="File" value="Logs/" />
<param name="AppendToFile" value="true"/>
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyy-MM-dd.'debug.log'" />
<param name="RollingStyle" value="Date"/>
<param name="MaxSizeRollBackups" value="10" />
<param name="MaximumFileSize" value="5MB" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%date [%thread] %-5level [%logger] %ndc - %message%newline" />
</layout>
<filter type="log4net.Filter.LevelRangeFilter">
<param name="LevelMin" value="DEBUG" />
<param name="LevelMax" value="DEBUG" />
</filter>
</appender>
<root>
<level value="All" />
<appender-ref ref="LogFileAppender" />
<appender-ref ref="ErrorFileAppender"/>
<appender-ref ref="DebugFileAppender" />
<appender-ref ref="ConsoleAppender" />
</root>
</log4net>將文件屬性中的“復(fù)制到輸出目錄”配置為始終復(fù)制,這樣配置文件會(huì)同步置執(zhí)行或發(fā)布目錄。

引用并初始化類(lèi)庫(kù)
static Program()
{
//加載log4net配置
log4net.Config.XmlConfigurator.ConfigureAndWatch(new FileInfo(AppDomain.CurrentDomain.BaseDirectory + @"\log4net.xml"));
}也可以在AssemblyInfo.cs中進(jìn)行初始化配置
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4Net.xml")]
工具類(lèi)
public static class LogHelper
{
public static void Info(object msg, params object[] parameters)
{
var log = LogManager.GetLogger("log4netlogger");
log.Info(msg);
}
public static void Debug(string msg)
{
var log = LogManager.GetLogger("log4netlogger");
log.Debug(msg);
}
public static void Error(string msg)
{
var log = LogManager.GetLogger("log4netlogger");
log.Error(msg);
}
public static void FormatError(string format, params object[] args)
{
var log = LogManager.GetLogger("log4netlogger");
log.Error(string.Format(format, args));
}
public static void Error(Exception ex)
{
var log = LogManager.GetLogger("log4netlogger");
log.Error(ex.Message, ex);
}
public static void Error(object msg, Exception ex)
{
var log = LogManager.GetLogger("log4netlogger");
log.Error(msg, ex);
}
public static void Warn(object msg, Exception ex)
{
var log = LogManager.GetLogger("log4netlogger");
log.Warn(msg, ex);
}
public static void Log(string msg)
{
Info(msg);
}
public static void Log(Exception ex)
{
Error(ex);
}
}調(diào)用示例
LogHelper.Info("事件類(lèi)型出錯(cuò),類(lèi)型:" + _rv.EventType + ",參數(shù):" + _rv.EventArgs);
LogHelper.Debug(string.Format("action_finish:{0}", TacticsName));
LogHelper.Error(string.Format("json序列化失?。簕0}", json), ex);到此這篇關(guān)于C# Winform使用log4net進(jìn)行日志記錄的文章就介紹到這了,更多相關(guān)C# log4net記錄日志內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C#獲得程序的根目錄以及判斷文件是否存在的實(shí)例講解
今天小編大家分享一篇C#獲得程序的根目錄以及判斷文件是否存在的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-06-06
C#進(jìn)行操作鼠標(biāo)和鍵盤(pán)的示例詳解
這篇文章主要為大家詳細(xì)介紹了如何使用C#進(jìn)行操作鼠標(biāo)和鍵盤(pán),文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,有需要的小伙伴可以參考一下2025-01-01
sqlserver備份還原數(shù)據(jù)庫(kù)功能封裝分享
這篇文章主要介紹了sqlserver備份還原數(shù)據(jù)庫(kù)功能封裝示例,需要的朋友可以參考下2014-03-03
c#讀取圖像保存到數(shù)據(jù)庫(kù)中(數(shù)據(jù)庫(kù)保存圖片)
這篇文章主要介紹了使用c#讀取圖像保存到數(shù)據(jù)庫(kù)中的方法,大家參考使用吧2014-01-01
unity實(shí)現(xiàn)動(dòng)態(tài)排行榜
這篇文章主要為大家詳細(xì)介紹了unity實(shí)現(xiàn)動(dòng)態(tài)排行榜,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07
winform 使用Anchor屬性進(jìn)行界面布局的方法詳解
這篇文章主要介紹了winform 使用Anchor屬性進(jìn)行界面布局的方法,有需要的朋友可以參考一下2013-12-12
詳解Unity中Mask和RectMask2D組件的對(duì)比與測(cè)試
本篇文章給大家介紹Unity中Mask和RectMask2D組件的對(duì)比與測(cè)試,包括組件用法及RectMask2D的基本用法,通過(guò)Mask的原理分析實(shí)例代碼相結(jié)合給大家講解的非常詳細(xì),需要的朋友參考下吧2021-06-06
C#獲取存儲(chǔ)過(guò)程返回值和輸出參數(shù)值的方法
這篇文章主要介紹了C#獲取存儲(chǔ)過(guò)程返回值和輸出參數(shù)值的方法,有需要的朋友可以參考一下2014-01-01
C#創(chuàng)建數(shù)據(jù)庫(kù)及附加數(shù)據(jù)庫(kù)的操作方法
這篇文章主要介紹了C#創(chuàng)建數(shù)據(jù)庫(kù)及附加數(shù)據(jù)庫(kù)的操作方法,涉及C#針對(duì)數(shù)據(jù)庫(kù)常見(jiàn)的創(chuàng)建、添加、連接等操作技巧,需要的朋友可以參考下2016-06-06

