当前位置: 首页 > article >正文

WPF log4net用法

WPF log4net用法

一、在工程中管理NuGet程序包,找到log4net,点击安装,如下图已成功安装;
在这里插入图片描述
二、在工程中右键添加新建项,选择应用程序配置文件(后缀为.config),然后设置名称,这里设置为Log4Net.config,文件里做如下配置:

<?xml version="1.0" encoding="utf-8" ?>
<configuration><configSections><section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/></configSections><!--日志配置部分--><log4net><root><!--控制级别,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF--><!--比如定义级别为INFO,则INFO级别向下的级别,比如DEBUG日志将不会被记录--><!--如果没有定义LEVEL的值,则缺省为DEBUG--><level value="ALL"/><appender-ref ref="RollingFileAppender"/></root><appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender"><!--日志文件存放位置,在debug文件夹下的log文件夹下--><file value="Logs/" /><!--是否追加到文件,默认为true,通常无需设置--><appendToFile value="true"/><!--这种情况下MaxSizeRollBackups和maximumFileSize的节点设置才有意义--><RollingStyle value="Composite"/><!--每天记录的日志文件个数,与maximumFileSize配合使用--><MaxSizeRollBackups value="-1"/><!--日期的格式,每天生成一个文件,每月会生成一个文件夹,存放当月的文件日志--><datePattern value="yyyy-MM&quot;/&quot;yyyyMMdd&quot;.txt&quot;"/><staticLogFileName value="false"/><!--多线程时采用最小锁定--><lockingModel type="log4net.Appender.FileAppender+MinimalLock"/><!--每个日志文件的大小,可用的单位:KB|MB|GB--><maximumFileSize value="2MB"/><!--日志格式--><layout type="log4net.Layout.PatternLayout"><conversionPattern value="%date [%t]%-5p %c - %m%n"/></layout></appender></log4net>
</configuration>

三、在工程Properties属性下找到AssemblyInfo.cs文件,在文件最后一行,添加如下格式的指定配置文件:

[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Log4Net.config", Watch = true)]

如下图:
在这里插入图片描述
四、我们添加一个Logger类:

public class Logger{private static readonly log4net.ILog loginfo = log4net.LogManager.GetLogger("loginfo");private static readonly log4net.ILog logerror = log4net.LogManager.GetLogger("logerror");public static void WriteInfo(string info){//Console.WriteLine(info);if (loginfo.IsInfoEnabled){loginfo.Info(info);}}public static void WriteError(string error){//Console.WriteLine(error);if (logerror.IsErrorEnabled){logerror.Error(error);}}public static void WriteError(string info, Exception ex){//Console.WriteLine(info);if (logerror.IsErrorEnabled){logerror.Error(info, ex);}}}

五、最后我们在需要记录日志的地方调用如下方法即可;

try{//......}catch (Exception ex){//记录异常Logger.WriteError(ex.ToString());}

六、在程序的根目录下,可以看到Logs文件夹下面就生成了Log文件;更多的生成Log方式可以通过配置config文件来设定;

http://www.lryc.cn/news/2393257.html

相关文章:

  • 数字孪生数据监控如何提升汽车零部件工厂产品质量
  • web自动化-Selenium、Playwright、Robot Framework等自动化框架使用场景优劣对比
  • 使用 Akamai 分布式云与 CDN 保障视频供稿传输安全
  • vue发版html 生成打包到docker镜像进行发版
  • python uv包管理器使用
  • 贪心算法实战3
  • linux、docker、git相关操作
  • 实测,大模型谁更懂数据可视化?
  • 小程序32-简易双向数据绑定
  • jenkins报错java.lang.OutOfMemoryError: Java heap space
  • leetcode669.修剪二叉搜索树:递归法利用有序性精准剪枝
  • Spring Boot 中 @RequestParam 和 @RequestPart 的区别详解(含实际项目案例)
  • Linux入门(十一)进程管理
  • 【课堂笔记】EM算法
  • 怎样将win11+ubuntu双系统的ubuntu从机械硬盘迁移至固态硬盘(1)
  • el-table设置自定义css
  • Compose中导航跳转的实现NavHost
  • VSCode/Cursor中Red Hat Dependency Analytics扩展的自动依赖注入files:分析
  • 【技能篇】RabbitMQ消息中间件面试专题
  • Linux研学-环境搭建
  • Ubuntu系统下可执行文件在桌面单击运行教程
  • Linux之文件进程间通信信号
  • shell脚本打包成可以在麒麟桌面操作系统上使用的deb包
  • 代码随想录算法训练营 Day61 图论ⅩⅠ Floyd A※ 最短路径算法
  • 【Python】yield from 功能解析
  • 私有云大数据部署:从开发到生产(Docker、K8s、HDFS/Flink on K8s)
  • 改写自己的浏览器插件工具 myChromeTools
  • python-pptx去除形状默认的阴影
  • kuboard自带ETCD存储满了处理方案
  • SpringBoot+tabula+pdfbox解析pdf中的段落和表格数据