WPF日志Log4net的使用总结

1.去nuget搜索Log4net并安装。

2.在app.config中添加配置文件

<configuration>
    <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.8" />
    </startup>
  <!--log4net配置start-->
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>
  <log4net>
    <root>
      <level value="ALL" />
    </root>
    <logger name="OperationLogger" additivity="false">
      <level value="ALL" />
      <appender-ref ref="FileAppender" />
      <appender-ref ref="UDPAppender" />
    </logger>
    <logger name="AlarmLogger" additivity="false">
      <level value="ALL" />
      <appender-ref ref="Alarm2FileAppender" />
    </logger>
    <appender name="FileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="D:/Logs/AheadLog.txt" />
      <appendToFile value="true" />
      <Encoding value="utf-8" />
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
      <rollingStyle value="Composite" /><!--Composite是Date+Size的意思-->
      <DatePattern value="yyyyMMdd'.txt'"></DatePattern>
      <maxSizeRollBackups value="1" /><!--每天最多2个备份文件--><!--比如只保留30天的log文件,必须用代码删除-->
      <maximumFileSize value="15MB" /><!--每个文件最大15兆-->&gt;
      <staticLogFileName value="true" />
      <filter type="log4net.Filter.LevelRangeFilter">
        <levelMin value="INFO" />
        <levelMax value="FATAL" />
      </filter>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date{yyyy-MM-dd|HH:mm:ss.fff}|%-5level|%message%newline" />
      </layout>
    </appender>
    <appender name="UDPAppender" type="log4net.Appender.UdpAppender">
      <remoteAddress value="127.0.0.1" />
      <remotePort value="7171" />
      <Encoding value="utf-8" />
      <layout type="log4net.Layout.PatternLayout, log4net">
        <conversionPattern value="%date{(MM/dd HH:mm:ss.fff)}|%level|%message%newline" />
      </layout>
    </appender>
    <appender name="Alarm2FileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="D:/LogAlarm/alarm.txt" />
      <appendToFile value="true" />
      <Encoding value="utf-8" />
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
      <rollingStyle value="Composite" /><!--Composite是Date+Size的意思-->
      <DatePattern value="yyyyMMdd'.txt'"></DatePattern>
      <maxSizeRollBackups value="1" /><!--每天最多2个备份文件--><!--比如只保留30天的log文件,必须用代码删除-->
      <maximumFileSize value="15MB" /><!--每个文件最大15兆-->&gt;
      <staticLogFileName value="true" />
      <filter type="log4net.Filter.LevelRangeFilter">
        <levelMin value="INFO" />
        <levelMax value="FATAL" />
      </filter>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date{yyyy-MM-dd|HH:mm:ss.fff}|%-5level|%message%newline" />
      </layout>
    </appender>
  </log4net>
</configuration>

3.在properties中的AssemblyInfo文件内添加下列代码

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

注意这里最好指定一下ConfigFile=“配置文件名称”,因为原来我没有加这一句导致日志一直记录不上

4.初始化并使用日志记录

public partial class MainWindow: Window
{
 public static log4net.ILog operationLog = log4net.LogManager.GetLogger("OperationLogger");
	public MainWindow()
	{
        InitializeComponent();
		operationLog.Info("启动");
	}
	
}

至此,每当调用operationLog.Info("");时,都会把日志写入日志文件。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值