C# 使用Log4net添加日志记录的方法
一、Log4net
官方网站:https://logging.apache.org/log4net/。
下载二进制dll库:
包中提供了针对各个版本的dll库:
二、使用日志库
1. 添加库
复制对应的库文件到项目中:
2. 配置log4net
2.1. 创建配置文件
添加后修改该文件设置:
2.2. 修改配置文件
替换文件为以下内容,设置为日志文件输出:
<?xml version="1.0" encoding="utf-8"?> <log4net> <!-- 文件存储日志配置 --> <appender name="RollingFile" type="log4net.Appender.RollingFileAppender"> <!-- 保存文件的名称 --> <file value="download.log" /> <appendToFile value="true" /> <!-- 文件的编码方式 --> <param name="Encoding" value="UTF-8"/> <!-- 每个文件的大小 --> <maximumFileSize value="100MB" /> <!-- 保存文件数量 --> <maxSizeRollBackups value="10" /> <!-- 日志输出格式 --> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date %-5level [%thread] %logger (%file:%line) - %message%newline" /> </layout> </appender> <root> <level value="ALL" /> <appender-ref ref="Console" /> <appender-ref ref="RollingFile" /> </root> </log4net>
2.3. 生效配置文件
修改 AssemblyInfo.cs
文件,添加这行:
// 指定log4net的配置文件 [assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", Watch = true)]
3. 使用log4net
引用库:
using log4net;
创建一个按钮,在按钮回调函数中测试log4net的使用:
namespace Log4netTest { public partial class Form1 : Form { private static ILog log = log4net.LogManager.GetLogger("Test"); public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { log.Error("这是一个错误", new Exception("发生异常!")); log.Fatal("这是一个致命错误", new Exception("发生致命错误")); log.Info("这是一个普通信息"); log.Warn("这是一个警告"); log.Debug("这是一个调试信息"); } } }
4. 结果
运行,点击按钮生成日志,在软件运行目录下找到日志文件:
到此这篇关于C# 使用Log4net添加日志记录的方法的文章就介绍到这了,更多相关C# Log4net添加日志记录内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
C#使用反射(Reflect)获取dll文件中的类型并调用方法
这篇文章主要为大家详细介绍了C#使用反射(Reflect)获取dll文件中的类型并调用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2018-10-10WinForm中BackgroundWorker控件用法简单实例
这篇文章主要介绍了WinForm中BackgroundWorker控件用法,以一个简单实例形式分析了BackgroundWorker控件的定义、设置及使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下2015-08-08C# BitArray(点矩阵)转换成int和string的方法实现
BitArray 类管理一个紧凑型的位值数组,它使用布尔值来表示,本文主要介绍了C# BitArray(点矩阵)转换成int和string的方法实现,具有一定的参考价值,感兴趣的可以了解一下2022-05-05C#常用多线程(线程同步,事件触发,信号量,互斥锁,共享内存,消息队列)
这篇文章主要介绍了C#常用多线程(线程同步,事件触发,信号量,互斥锁,共享内存,消息队列),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-09-09
最新评论