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

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文件来设定;

相关文章:

  • Facebook 的隐私保护措施是否足够?技术观点
  • 1614. 括号的最大嵌套深度【 力扣(LeetCode) 】
  • LVS+KeepAlived
  • ansible template 文件中如果包含{{}} 等非ansible 变量处理
  • 【python深度学习】Day 39 图像数据与显存
  • 关于 JavaScript 版本、TypeScript、Vue 的区别说明, PHP 开发者入门 Vue 的具体方案
  • 2.spring基础入门(二)
  • 充电便捷,新能源汽车移动充电服务如何预约充电
  • 数字孪生数据监控如何提升汽车零部件工厂产品质量
  • 汽车制造场景下Profibus转Profinet网关核心功能与应用解析
  • 新能源汽车电控系统的精准守护者PKDV5355高压差分探头
  • 【JS进阶】JavaScript 中 this 值的确定规则
  • 单片机——keil5
  • CUDA 归约求和(Reduction)算法
  • Java AQS(Abstract Queued Synchronized)深度解析
  • 使用 Arthas 查看接口方法执行时间
  • MVCC(多版本并发控制)机制
  • C++双线程交替打印奇偶数(活泼版)
  • 【java】aes,salt
  • CAN通信波特率异常的危害
  • 大型购物网站建设方案/建立网站一般要多少钱
  • 湖州吴兴建设局网站/seo外链软件
  • 鸿鹄网站建设/惠州seo排名优化
  • 银川网站开发/公司网络推广网站
  • 怎么做网站销售/seo外包 杭州
  • 彩票投资理财平台网站建设/河南seo快速排名