C#Log4net记录日志(转)

Posted lizhongzhongy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#Log4net记录日志(转)相关的知识,希望对你有一定的参考价值。

C#Log4net记录日志

1、下载log4net地址:http://logging.apache.org/log4net/download_log4net.cgi

下载log4net-2.0.8-bin-oldkey.zip到本地,根据自己的需求选择一个合适的log4net.dll版本即可。

2、log4net.dll放在 \bin\Release或者 \bin\Debug下。

3、解决方案下的引用中去引用该dll。

4、添加一个App.config,可网上查询添加的节点。这里添加一个我自己可以用的。

<?xml version="1.0" encoding="utf-8"?>
<configuration>
    <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/>
    </startup>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
  </configSections>
  <!--日志-->
  <log4net>
    <logger name="Logerror">
      <level value="ALL"/>
      <appender-ref ref="Log_error"/>
    </logger>
    <logger name="Loginfo">
      <level value="DEBUG"/>
      <appender-ref ref="Log_info"/>
    </logger>
    <!--<logger name="logconsole">
      <level value="INFO" />
      <appender-ref ref="ConsoleAppender" />
    </logger>-->
    <!--信息日志-->
    <appender name="Log_error" type="log4net.Appender.RollingFileAppender">
      <!--定义日志存放位置-->
      <param name="File" value="E:\Logs\error.log"/>
      <param name="DatePattern" value="yyyyMMdd"/>
      <param name="AppendToFile" value="true"/>
      <param name="MaxSizeRollBackups" value="100"/>
      <param name="MaximumFileSize" value="1MB"/>
      <param name="RollingStyle" value="Size"/>
      <param name="StaticLogFileName" value="true"/>
      <layout type="log4net.Layout.PatternLayout">
        <!--输出格式-->
        <param name="ConversionPattern" value="%-5level %date %file %type %method() %line %message %n"/>
      </layout>
    </appender>
    <appender name="Log_info" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="E:\Logs\info.log"/>
      <param name="DatePattern" value="yyyyMMdd"/>
      <param name="AppendToFile" value="true"/>
      <param name="MaxSizeRollBackups" value="100"/>
      <param name="MaximumFileSize" value="1MB"/>
      <param name="RollingStyle" value="Size"/>
      <param name="StaticLogFileName" value="true"/>
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%-5level %d [%c] %m%n"/>
      </layout>
      <filter type="log4net.Filter.LevelRangeFilter">
        <param name="LevelMin" value="INFO"/>
        <param name="LevelMax" value="ERROR"/>
      </filter>
    </appender>
  </log4net>
</configuration>

 

5、AssemblyInfo.cs中最后一句添加
[assembly: log4net.Config.XmlConfigurator(ConfigFileExtension = "config", Watch = true)]
否则的话不能写入日志。

6、winform中可以单独建一个类用于存放log4net的实例化。

当然了需要注意的是log4net.LogManager.GetLogger(“Logerror和Loginfo”)中的“MSgLogger”要与App.config中相对应。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace demo

    class Loghelper
    
        public static log4net.ILog logerror = log4net.LogManager.GetLogger("Logerror");
        public static log4net.ILog loginfo = log4net.LogManager.GetLogger("Loginfo");
    
    

 

7、测试一下

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace demo

    public partial class Form1 : Form
    
        
        public Form1()
        
            InitializeComponent();
            Loghelper.loginfo.Info("ssss");
            Loghelper.logerror.Info("Look look error log.");

        
    

 

8、大功告成

以上是关于C#Log4net记录日志(转)的主要内容,如果未能解决你的问题,请参考以下文章

log4net记录(转)

(转)Log4Net 详解

Log4net 可以在新创建的 AppDomain 中运行吗

log4net服务启动后没有记录日志

多线程代码执行的 Log4Net C# 日志记录问题

csharp 用C#编写的简单SMTP邮件客户端助手类,用于异步发送电子邮件。注意:使用Log4Net进行日志记录。