以下是帮助类(在程序集中引入log4net.dll):
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;
}
}
以下是配置文件:
获取配置文件(Properties文件夹中):[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Configs\\log4net.config", Watch = true)]
log4net.config配置文件:
<?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>
引用:
LogHelper.ErrorLog(“初始化相机错误:”, ex);//错误日志
LogHelper.WriteLog(“保存图片:” + dsd + " " + filename);//提示日志