首页 > 其他分享 >log4net简单使用

log4net简单使用

时间:2022-11-04 15:01:01浏览次数:94  
标签:log4net info string errorMsg 简单 static ex 使用

参考(15条消息) C#中实现日志记录功能_微笑&星空的博客-CSDN博客_c#日志记录

 

1.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&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>

 

2.在配置文件添加

以下是配置文件:
获取配置文件(Properties文件夹中):[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Configs\\log4net.config", Watch = true)]

 

3.创建Hepler类

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;
}
}

4.使用

LogHelper.ErrorLog(“初始化相机错误:”, ex);//错误日志
LogHelper.WriteLog(“保存图片:” + dsd + " " + filename);//提示日志

 

标签:log4net,info,string,errorMsg,简单,static,ex,使用
From: https://www.cnblogs.com/ZY2022/p/16857786.html

相关文章

  • netty系列之: 在netty中使用 tls 协议请求 DNS 服务器
    目录简介支持DoT的DNS服务器搭建支持DoT的netty客户端TLS的客户端请求总结简介在前面的文章中我们讲过了如何在netty中构造客户端分别使用tcp和udp协议向DNS服务器请求消......
  • SQLite简单使用
    SQLite是什么?首先它是一个数据库有什么特点?是一个嵌入式的数据库,存储形式为一个文件,不需要任何配置,比如说在python中想使用它,直接import简单使用#导入数据库imp......
  • MATLAB使用手记(一):绘制余弦信号图形
    前言记录下matlab使用过程的一些应用笔记基本余弦信号\[f(x)=A\cos(\omegat+\phi)=A\cos(2\pift+\phi)\]余弦信号基本公式如上,其中\(A\)是振幅、\(f\)是频率,\(\ome......
  • 微信小程序中wx.login和wx.getUserProfile的使用
    在使用微信登录时,通常会在调用wx.login获取code后再通过wx.getUserProfile获取iv和encryptedData(加密数据)一起发到后端进行登录验证在实际使用中如果在wx.login方法......
  • lambda表达式使用局部变量要用final
    为什么Lambda表达式(匿名类)不能访问非final的局部变量呢?  因为实例变量存在堆中,而局部变量是在栈上分配,Lambda表达式(匿名类)会在另一个线程中执行。如果在线程......
  • 逻辑分析仪使用介绍
    KingstVIS逻辑分析仪使用介绍@目录KingstVIS逻辑分析仪使用介绍一:逻辑分析仪是什么二:采样原理三:和示波器有什么区别四:产品介绍五:软件介绍六:设备连接七:使用详解八:常见......
  • 在子类中,若要调用父类中被覆盖的方法,可以使用super关键字
    packagetext;classParent{   intx;   publicParent()   {                System.out.println("ParentCreated1");    }  ......
  • 本地为内网无公网IP如何使用HTTP代理授权
    很多朋友在使用HTTP代理进行授权时,发现自己本地运营商根本没有分配公网IP,全部都是内网,无法进行IP白名单绑定授权,遇到这种情况,我们应该怎么办呢?要知道,绑定白名单,给......
  • Elasticsearch 同时使用should和must 只有must生效,java代码解决方案
    ES中同时使用should和must导致只有must生效解决方案失效的原因就是must和should在一起使用会不生效,如果全部都是must是不影响的.加入一个字段需要有类似url=aor......
  • vue中的依赖注入provide和inject(简单易懂)
    本文开始,首先我们来看这两个词的意思,provide:提供  inject:注入 用处:父组件可以向其所有子组件传入数据,而“不管子组件层次结构有多深(非父子和父子咱都能传)” 特性......