一. Log4Net简介
Log4net是从Java中的Log4j迁移过来的一个.Net版的开源日志框架,它的功能很强大,可以将日志分为不同的等级,以不同的格式输出到不同的存储介质中,比如:数据库、txt文件、内存缓冲区、邮件、控制台、ANSI终端、远程接收端等等,我们这里主要介绍最常用的两种:txt文件和数据库。其它的存储介质详见Apache log4net – Apache log4net: Config Examples - Apache log4nethttps://logging.apache.org/log4net/release/config-examples.html Log4net将日志分为五个级别,分别是: FATAL(致命错误) > ERROR(一般错误) > WARN(警告) > INFO(一般信息) > DEBUG(调试信息),每个级别都对应着一组重载方法进行调用。
官网地址:http://logging.apache.org/log4net/index.html
Nuget地址:https://www.nuget.org/packages/log4net/
Nuget安装:Install-Package log4net
二、使用
2.1下载log4net
2.2添加引用
2.3添加配置文件
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
</configSections>
<log4net>
<logger name="loginfo">
<level value="INFO" />
<appender-ref ref="InfoAppender" />
</logger>
<!--type表示用什么类型记录日志 RollingFileAppender代表用文本来记录日志-->
<appender name="InfoAppender" type="log4net.Appender.RollingFileAppender,log4net">
<!--日志文件的保存位置为:log/Log-20210523.txt-->
<param name="File" value="log\\LogInfo\\"/>
<!--日志文件名为Log-20210523.txt格式 每天日志分别对应到一个文件中-->
<param name="DatePattern" value="yyyyMMdd".log""/>
<!--日志文件名,是否固定不变 如果想在文件名称后面加上日期参数,则应为false-->
<param name="StaticLogFileName" value="false" />
<!--日志文件为后续内容附加到已有文件(若是false,则为后续覆盖向前的内存)-->
<param name="AppendToFile" value="true" />
<!--根据文件的大小和日期滚动文件-->
<param name="RollingStyle" value="Date" />
<!--备份文件的个数-->
<param name="MaxSizeRollBackups" value="100"/>
<!--如果我们将最大文件大小设置为1MB并将maxSizeRollBackups设置为10 MB,那么根据日期或文件大小,它将只保留最后10MB的文件-->
<param name="MaximumFileSize" value="1MB" />
<layout type="log4net.Layout.PatternLayout,log4net">
<!--日志记录的格式-->
<!--<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />格式为:时间+[线程]+级别+项目.Controller -messsage+exception.innerMessage-->
<param name="ConversionPattern" value="记录时间:%date 线程ID:[%thread] 日志级别:%-5level 日志描述:%message%newline" />
<!--格式类似:记录时间:2020-01-15 20:34:37,946 线程ID:[6] 日志级别:DEBUG 出错类:_008Log4Net.Controllers.HomeController property:[(null)] - 错误描述:Hi I am log4net Debug Level-->
</layout>
</appender>
<logger name="logerror">
<level value="ERROR" />
<appender-ref ref="RollingLogFileAppender" />
</logger>
<!--type表示用什么类型记录日志 RollingFileAppender代表用文本来记录日志-->
<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender,log4net">
<!--日志文件的保存位置为:log/Log-20210523.txt-->
<param name="File" value="log\\LogError\\"/>
<!--日志文件名为Log-20210523.txt格式 每天日志分别对应到一个文件中-->
<param name="DatePattern" value="yyyyMMdd".log""/>
<!--日志文件名,是否固定不变 如果想在文件名称后面加上日期参数,则应为false-->
<param name="StaticLogFileName" value="false" />
<!--日志文件为后续内容附加到已有文件(若是false,则为后续覆盖向前的内存)-->
<param name="AppendToFile" value="true" />
<!--根据文件的大小和日期滚动文件-->
<param name="RollingStyle" value="Date" />
<!--备份文件的个数-->
<param name="MaxSizeRollBackups" value="100"/>
<!--如果我们将最大文件大小设置为1MB并将maxSizeRollBackups设置为10 MB,那么根据日期或文件大小,它将只保留最后10MB的文件-->
<param name="MaximumFileSize" value="1MB" />
<layout type="log4net.Layout.PatternLayout,log4net">
<!--日志记录的格式-->
<!--<param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />格式为:时间+[线程]+级别+项目.Controller -messsage+exception.innerMessage-->
<param name="ConversionPattern" value="记录时间:%date 线程ID:[%thread] 日志级别:%-5level 错误描述:%message%newline" />
<!--格式类似:记录时间:2020-01-15 20:34:37,946 线程ID:[6] 日志级别:DEBUG 出错类:_008Log4Net.Controllers.HomeController property:[(null)] - 错误描述:Hi I am log4net Debug Level-->
</layout>
</appender>
</log4net>
</configuration>
2.4程序启动时读取log4net的配置文件
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", Watch = true)]
将配置文件放置该文件下
2.5日志类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.InteropServices;
using System.Text;
using System.Threading.Tasks;
namespace geoscenepro_automation
{
public static class LogHelper
{
public static readonly log4net.ILog loginfo = log4net.LogManager.GetLogger("loginfo");
public static readonly log4net.ILog logerror = log4net.LogManager.GetLogger("logerror");
public static void WriteLog(string info)
{
if (loginfo.IsInfoEnabled)
{
loginfo.Info(info);
}
}
/// <summary>
/// 错误记录
/// </summary>
/// <param name="info">附加信息</param>
/// <param name="ex">错误</param>
public static void ErrorLog(string info, Exception ex)
{
if (!string.IsNullOrEmpty(info) && ex == null)
{
logerror.ErrorFormat("【附加信息】 : {0}<br>", new object[] { info });
}
else if (!string.IsNullOrEmpty(info) && ex != null)
{
string errorMsg = BeautyErrorMsg(ex);
logerror.ErrorFormat("【附加信息】 : {0}<br>{1}", new object[] { info, errorMsg });
}
else if (string.IsNullOrEmpty(info) && ex != null)
{
string errorMsg = BeautyErrorMsg(ex);
logerror.Error(errorMsg);
}
}
/// <summary>
/// 美化错误信息
/// </summary>
/// <param name="ex">异常</param>
/// <returns>错误信息</returns>
private static string BeautyErrorMsg(Exception ex)
{
string errorMsg = string.Format("【异常类型】:{0} <br>【异常信息】:{1} <br>【堆栈调用】:{2}", new object[] { ex.GetType().Name, ex.Message, ex.StackTrace });
errorMsg = errorMsg.Replace("\r\n", "<br>");
errorMsg = errorMsg.Replace("位置", "<strong style=\"color:red\">位置</strong>");
return errorMsg;
}
}
}
2.6运行
尝试添加按钮进行日志文件书写
2.7结果
三、示例链接
四、参考
log4net使用中loginfo.IsInfoEnabled=false问题解决方法_ChaoYang0502的博客-CSDN博客
Log4Net日志详解_zhanglong_longlong的博客-CSDN博客
C#中实现日志记录功能_c# 日志_微笑&星空的博客-CSDN博客
log4net使用中loginfo.IsInfoEnabled=false问题解决方法_zwm_16的博客-CSDN博客