1、下載log4net地址:http://logging.apache.org/log4net/download_log4net.cgi 下載log4net-2.0.8-bin-oldkey.zip到本地,根據自己的需求選擇一個合適的log4net.dll版本即可。 2、log4net.dll放在 ...
1、下載log4net地址:http://logging.apache.org/log4net/download_log4net.cgi
下載log4net-2.0.8-bin-oldkey.zip到本地,根據自己的需求選擇一個合適的log4net.dll版本即可。
2、log4net.dll放在 \bin\Release或者 \bin\Debug下。
3、解決方案下的引用中去引用該dll。
4、添加一個App.config,可網上查詢添加的節點。這裡添加一個我自己可以用的。
<?xml version="1.0" encoding="utf-8"?> <configuration> <startup> <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/> </startup> <configSections> <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/> </configSections> <!--日誌--> <log4net> <logger name="Logerror"> <level value="ALL"/> <appender-ref ref="Log_error"/> </logger> <logger name="Loginfo"> <level value="DEBUG"/> <appender-ref ref="Log_info"/> </logger> <!--<logger name="logconsole"> <level value="INFO" /> <appender-ref ref="ConsoleAppender" /> </logger>--> <!--信息日誌--> <appender name="Log_error" type="log4net.Appender.RollingFileAppender"> <!--定義日誌存放位置--> <param name="File" value="E:\Logs\error.log"/> <param name="DatePattern" value="yyyyMMdd"/> <param name="AppendToFile" value="true"/> <param name="MaxSizeRollBackups" value="100"/> <param name="MaximumFileSize" value="1MB"/> <param name="RollingStyle" value="Size"/> <param name="StaticLogFileName" value="true"/> <layout type="log4net.Layout.PatternLayout"> <!--輸出格式--> <param name="ConversionPattern" value="%-5level %date %file %type %method() %line %message %n"/> </layout> </appender> <appender name="Log_info" type="log4net.Appender.RollingFileAppender"> <param name="File" value="E:\Logs\info.log"/> <param name="DatePattern" value="yyyyMMdd"/> <param name="AppendToFile" value="true"/> <param name="MaxSizeRollBackups" value="100"/> <param name="MaximumFileSize" value="1MB"/> <param name="RollingStyle" value="Size"/> <param name="StaticLogFileName" value="true"/> <layout type="log4net.Layout.PatternLayout"> <param name="ConversionPattern" value="%-5level %d [%c] %m%n"/> </layout> <filter type="log4net.Filter.LevelRangeFilter"> <param name="LevelMin" value="INFO"/> <param name="LevelMax" value="ERROR"/> </filter> </appender> </log4net> </configuration>
5、AssemblyInfo.cs中最後一句添加[assembly: log4net.Config.XmlConfigurator(ConfigFileExtension = "config", Watch = true)],否則的話不能寫入日誌。
6、winform中可以單獨建一個類用於存放log4net的實例化。
當然了需要註意的是log4net.LogManager.GetLogger("Logerror和Loginfo")中的“MSgLogger”要與App.config中相對應。
1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 7 namespace demo 8 { 9 class Loghelper 10 { 11 public static log4net.ILog logerror = log4net.LogManager.GetLogger("Logerror"); 12 public static log4net.ILog loginfo = log4net.LogManager.GetLogger("Loginfo"); 13 } 14 15 }
7、測試一下
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; namespace demo { public partial class Form1 : Form { public Form1() { InitializeComponent(); Loghelper.loginfo.Info("ssss"); Loghelper.logerror.Info("Look look error log."); } } }
8、大功告成