C#中实现日志记录功能

以下是帮助类(在程序集中引入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&quot;.log&quot;"/>
			<!--日志文件名,是否固定不变 如果想在文件名称后面加上日期参数,则应为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&quot;.log&quot;"/>
			<!--日志文件名,是否固定不变 如果想在文件名称后面加上日期参数,则应为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);//提示日志

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值