Step1、引用log4net,通过NuGet下载,输入log,查询后如下图,安装Apache log4net,这里以VS2019为例;
工具-》nuget包管理器-》管理解决方案的nuget程序包-》浏览-》输入“log”回车-》-》点击"log4net"-》选择右边我们要添加log4net的项目-》选择版本-》安装即可,安装完成后项目会自动引用log4net。
Step2、在AssemblyInfo.cs代码末尾加上以上代码:
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", ConfigFileExtension = "config", Watch = true)]
这里要注意ConfigFile其实是一个相对路径,并且指的是Debug路径下,我们也可以在Debug文件夹下新建一个文件夹比如AppConfig(新建文件有时候会有问题,在不同的电脑上会出现不同的情况,建议直接拷贝现有的config文件log4net.config文件下载)),然后将"log4net.config"放置到Debug文件夹下,那么我们这里的ConfigFile="AppConfig\log4net. config"或者ConfigFile="AppConfig/log4net. config"即可。
Step3、在程序运行目录下,新建log4net.config文件,并将以下内容添加进去,
<log4net>
<logger name="logerror">
<level value="ALL" />
<appender-ref ref="ErrorAppender" />
</logger>
<logger name="loginfo">
<level value="ALL" />
<appender-ref ref="InfoAppender" />
</logger>
<appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="Log\\LogError\\" />
<param name="AppendToFile" value="true" />
<param name="MaxSizeRollBackups" value="100" />
<param name="MaximumFileSize" value="10240" />
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyyMMdd".htm"" />
<param name="RollingStyle" value="Date" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="<HR COLOR=red>%n异常时间:%d [%t] <BR>%n异常级别:%-5p <BR>%n异 常 类:%c [%x] <BR>%n%m <BR>%n <HR Size=1>" />
</layout>
</appender>
<appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="Log\\LogInfo\\" />
<param name="AppendToFile" value="true" />
<param name="MaximumFileSize" value="102KB" />
<param name="MaxSizeRollBackups" value="10" />
<param name="StaticLogFileName" value="false" />
<param name="DatePattern" value="yyyyMMdd".htm"" />
<param name="RollingStyle" value="Composite" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="<HR COLOR=blue>%n日志时间:%d [%t] <BR>%n日志级别:%-5p <BR>%n日 志 类:%c [%x] <BR>%n%m <BR>%n <HR Size=1>" />
</layout>
</appender>
</log4net>
Step4、新建LogHelp类,代码如下:
class LogHelp
{
public static readonly log4net.ILog loginfo = log4net.LogManager.GetLogger("loginfo");
public static readonly log4net.ILog logerror = log4net.LogManager.GetLogger("logerror");
private static object thisLock = new object();
public static void WriteLog(string info, bool realWriteLog = true)
{
lock (thisLock)
{
if(realWriteLog)
{
if (loginfo.IsInfoEnabled)
{
loginfo.Info(info);
}
}
}
}
public static void WriteLog(string info, Exception se,bool realWriteLog=true)
{
lock (thisLock)
{
if(realWriteLog)
{
if (logerror.IsErrorEnabled)
{
logerror.Error(info, se);
}
}
}
}
/// <summary>
/// 日志保留多少天
/// </summary>
/// <param name="logFilePath"></param>
/// <param name="saveDays"></param>
public static void SaveLogDays(string logFilePath, int saveDays)
{
lock (thisLock)
{
string[] logFileName = Directory.GetFiles(logFilePath);
if (logFileName.Count() > saveDays)
{
File.Delete(logFileName[0]);
}
}
}
}
Step5、客户端调用如下:
LogHelp.WriteLog("123");
LogHelp.WriteLog("456",new Exception ("错误"));
总结:
1) 以上要注意上述配置是按照日期+文件大小的格式,按照每天的格式,一天最多10个文件,超过10个则用最新的替代旧的文件,且每个文件的最大值为102KB。
2)如果只是按照文件日期配置的话,则将<param name="RollingStyle" value="Composite" />
改为<param name="RollingStyle" value="Date" />
,则文件按照每天一个文件的格式来记录。
3)如果只是按照文件大小配置的话,则将<param name="RollingStyle" value="Composite" />
改为<param name="RollingStyle" value="Size" />
,并且要执行文件名,因为不按照日期的话,日志就不知道log日志的文件名是什么了,也就是将<param name="File" value="Log\\LogInfo\\" />
改为<param name="File" value="Log\\LogInfo\\logInfo.txt" />
,将 <param name="File" value="Log\\LogError\\" />
改为 <param name="File" value="Log\\LogError\\logError.txt" />
即可。