图片 5

转发加个人观点,log4net使用办法

1.NuGet包管理器中安装log4net

  • 原文地址:
  • 配置文件解析地址:
  • 1.引入库log4net.dll

  • 2.展开项目文件下的Properties文件夹,打开AssemblyInfo.cs并在AssemblyInfo.cs中添加一行:在AssemblyInfo.cs中添加一行:(其中log4net.config对应配置文件名)

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

众所周知log4net是一个很强大的日志管理库,我自己也用了下,这里作下记录:

图片 1

  

首先新建一个项目Log4NetTest,然后将log4net.dll程序集添加引用至Log4NetTest。

2.接着在项目中添加log4net.config文件,以及手撸或寻找一个LogHelper

 

然后在Log4NetTest项目中的Properties ->
AssemblyInfo.cs文件中添加:[assembly:log4net.Config.XmlConfigurator(Watch
= true)],如图:

添加完log4net.config一定要设置属性,将其始终复制到输出目录

  • 3.添加log4net.config配置文件:

图片 2

图片 3

这句代码也可以添加到名称空间前面,但是这种方式log4net就只局限于该名称空间内可用,其它名称空间要用也要写这句代码,故可以直接加在AssemblyInfo.cs中作用于整个项目。

 

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="System.Configuration.IgnoreSectionHandler"/>
  </configSections>
  <log4net>
    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="loglogfile.log"/>
      <appendToFile value="true"/>
      <rollingStyle value="Composite"/>
      <datePattern value="yyyyMMdd"/>
      <maxSizeRollBackups value="10"/>
      <maximumFileSize value="1MB"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline"/>
      </layout>
    </appender>
    <root>
      <level value="All"/>
      <appender-ref ref="RollingLogFileAppender"/>
    </root>
  </log4net>
  <startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5"/>
  </startup>
</configuration>

然后在App.config中写相应的log4net所需的配置信息,写好后就可以在Main函数中用代码:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>
  <log4net xsi:noNamespaceSchemaLocation="http://csharptest.net/downloads/schema/log4net.xsd"
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <root>
      <level value="DEBUG"/>
      <appender-ref ref="ErrorRollingFileAppender"/>
      <appender-ref ref="WarnRollingFileAppender"/>
      <appender-ref ref="InfoRollingFileAppender"/>
      <appender-ref ref="DebugRollingFileAppender"/>
    </root>

    <!--一般错误日志定义,用于记录已知需处理的与未捕获的异常-->
    <!--日志输出格式:[时间]:类名 线程号 消息-->
    <appender name="ErrorRollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <filter type="log4net.Filter.LevelRangeFilter">
        <levelMin value="ERROR"/>
        <levelMax value="FATAL"/>
      </filter>
      <filter type="log4net.Filter.DenyAllFilter"/>
      <file value="logs"/>
      <rollingStyle value="Date"/>
      <datePattern value="yyyy-MM-dd\&quot;Error.log&quot;"/>
      <staticLogFileName value="false"/>
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="[%d{yyyy-MM-dd HH:mm:ss.fff}] %-5p %c.%M %t %n%m%n"/>
      </layout>
    </appender>

    <!--警告日志定义,用于记录已知不需处理的异常,系统警告信息-->
    <!--日志输出格式:[时间]:类名 线程号 消息-->
    <appender name="WarnRollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <filter type="log4net.Filter.LevelMatchFilter">
        <levelToMatch value="WARN"/>
      </filter>
      <filter type="log4net.Filter.DenyAllFilter"/>
      <file value="logs"/>
      <appendToFile value="true"/>
      <rollingStyle value="Date"/>
      <datePattern value="yyyy-MM-dd\&quot;Warn.log&quot;"/>
      <staticLogFileName value="false"/>
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="[%d{yyyy-MM-dd HH:mm:ss.fff}] %c.%M %t %m%n"/>
      </layout>
    </appender>

    <!--信息日志定义,用于记录用户相关信息-->
    <!--日志输出格式:[时间]:消息-->
    <appender name="InfoRollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <filter type="log4net.Filter.LevelMatchFilter">
        <levelToMatch value="INFO"/>
      </filter>
      <filter type="log4net.Filter.DenyAllFilter"/>
      <file value="logs"/>
      <appendToFile value="true"/>
      <rollingStyle value="Date"/>
      <datePattern value="yyyy-MM-dd\&quot;Info.log&quot;"/>
      <staticLogFileName value="false"/>
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="[%d{yyyy-MM-dd HH:mm:ss}] %m%n"/>
      </layout>
    </appender>

    <!--信息日志定义,用于收集开发调试信息-->
    <!--日志输出格式:[时间]:类名 线程号 消息-->
    <appender name="DebugRollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <filter type="log4net.Filter.LevelMatchFilter">
        <levelToMatch value="DEBUG"/>
      </filter>
      <filter type="log4net.Filter.DenyAllFilter"/>
      <file value="logs"/>
      <appendToFile value="true"/>
      <rollingStyle value="Date"/>
      <datePattern value="yyyy-MM-dd\&quot;Debug.log&quot;"/>
      <staticLogFileName value="false"/>
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="[%d{yyyy-MM-dd HH:mm:ss.fff}] %c %t:%m%n"/>
      </layout>
    </appender>

  </log4net>
</configuration>

  

ILog log = LogManager.GetLogger(typeof (Program));  // typeof(Program)的作用貌似是与 引用当前程序集有关。
            log.Error("ErrMsg", new Exception("Error异常。"));
            log.Fatal("FatalMsg", new Exception("Fatal异常。"));
            log.Info("InfoMsg", new Exception("Info信息。"));
            log.Debug("DebugMsg", new Exception("Debug信息。"));
            log.Warn("WarnMsg", new Exception("我怎么"));
            Console.WriteLine("Log It's Ok");
            Console.ReadKey();

 

 

如果想将log4net的配置写在一个单独的.config文件中,如log4net.config,则需要

 1     public static class LogHelper
 2     {
 3         private static readonly log4net.ILog Logerror = log4net.LogManager.GetLogger("DEBUG");
 4 
 5         public static void WriteInfoLog(string info)
 6         {
 7             Logerror.Info(info);
 8         }
 9 
10         public static void WriteErrorLog(string info)
11         {
12             Logerror.Error(info);
13         }
14 
15         public static void WriteDebugLog(string info)
16         {
17             Logerror.Debug(info);
18         }
19 
20         public static void WriteDebugLog(Exception exception)
21         {
22             Logerror.Debug(exception.Message, exception);
23         }
24     }
  • 4.添加一个公共的日志管理类AppLog.cs

    using System;
    using System.Collections.Generic;
    using System.Text;
    using log4net;
    using log4net.Config;
    using System.IO;

修改[assembly:log4net.Config.XmlConfigurator(Watch =
true)]为:[assembly: log4net.Config.XmlConfigurator(ConfigFile = ``"log4net.config"``, Watch = ``true``)]。

 3.最后需要在AssemblyInfo.cs中添加一行代码

namespace log4net
{
    /// <summary>
    /// 使用Log4net插件的log日志对象
    /// </summary>
    public static class AppLog
    {
        private static ILog log;

        static AppLog()
        {
            XmlConfigurator.ConfigureAndWatch(new FileInfo(AppDomain.CurrentDomain.SetupInformation.ConfigurationFile));
            log = LogManager.GetLogger(typeof(AppLog));
        }

        public static void Debug(object message)
        {
            log.Debug(message);
        }

        public static void DebugFormatted(string format, params object[] args)
        {
            log.DebugFormat(format, args);
        }

        public static void Info(object message)
        {
            log.Info(message);
        }

        public static void InfoFormatted(string format, params object[] args)
        {
            log.InfoFormat(format, args);
        }

        public static void Warn(object message)
        {
            log.Warn(message);
        }

        public static void Warn(object message, Exception exception)
        {
            log.Warn(message, exception);
        }

        public static void WarnFormatted(string format, params object[] args)
        {
            log.WarnFormat(format, args);
        }

        public static void Error(object message)
        {
            log.Error(message);
        }

        public static void Error(object message, Exception exception)
        {
            log.Error(message, exception);
        }

        public static void ErrorFormatted(string format, params object[] args)
        {
            log.ErrorFormat(format, args);
        }

        public static void Fatal(object message)
        {
            log.Fatal(message);
        }

        public static void Fatal(object message, Exception exception)
        {
            log.Fatal(message, exception);
        }

        public static void FatalFormatted(string format, params object[] args)
        {
            log.FatalFormat(format, args);
        }
    }
}

且要将log4net.config文件设置为复制到输出目录。(推荐将log4net的配置写在单独的配置文件中)

 图片 4

  • 5.在任何你想写日志的地方使用,例如:

    AppLog.Info(“Info log”);
    AppLog.Error(“Error log”);

log4net.config中的配置信息可为:

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

  

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
    </configSections>

    <log4net>

        <root>
            <level value="ALL" />
            <appender-ref ref="InfoAppender" />
            <appender-ref ref="WarnAppender" />
            <appender-ref ref="ErrorAppender" />
            <appender-ref ref="FatalAppender" />
            <appender-ref ref="DebugAppender" />
        </root>

        <!-- 输出模式定义 -->
        <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
            <!--日志路径: 兼容相对路径和绝对路径,此语句等价于<File value="Logs"/> -->
            <param name= "File" value= "Logs"/>
            <!--是否是向文件中追加日志-->
            <param name= "AppendToFile" value= "true"/>
            <!--保留天数-->
            <param name= "MaxSizeRollBackups" value= "-1"/>
            <!--日志文件名是否固定不变的-->
            <param name= "StaticLogFileName" value= "false"/>
            <!--日志文件名格式为:2017-01-12_Info.log-->
            <param name= "DatePattern" value= "yyyy-MM-dd&quot;_Info.log&quot;"/>
            <!--日志根据日期滚动-->
            <param name= "RollingStyle" value= "Date"/>
       <!-- 每条记录的头和尾 -->
       <header value="{*" />
       <footer value="*}" /> 
            <!-- 写入记录文件时的格式%p应该指模式如WARN,%m应该指Message值,%n应该是换行的意思。接着输出Exception -->
            <layout type="log4net.Layout.PatternLayout">
                <param name="ConversionPattern" value="%date{yyyy-MM-dd HH:mm:ss.fff} %-8p %m%n" />
            </layout>
            <!-- 此模式输出的级别范围 -->
       <!-- FATAL > ERROR > WARN > INFO > DEBUG --> 
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="INFO" />
                <levelMax value="INFO" />
            </filter>
        </appender>

        <appender name="WarnAppender" type="log4net.Appender.RollingFileAppender">
            <File value= "Logs"/>
            <param name= "AppendToFile" value= "true"/>
            <param name= "MaxSizeRollBackups" value= "10"/>
            <!-- 能保存的文件最大值,假设某次输出后该文件如mm_warn.log的大小将会超过最大值3KB,则此次输出仍有效,但是下次输出则会将该文件重命名为mm_warn.log.1,且生成一个新的mm_warn.log文件以供记录输出内容。 -->
            <param name="MaximumFileSize" value="3KB" />
            <param name= "StaticLogFileName" value= "false"/>
            <param name= "DatePattern" value= "yyyy-MM-dd&quot;_Warn.log&quot;"/>
            <param name= "RollingStyle" value= "Composite"/>
            <!-- 写入记录文件时的格式 -->
            <layout type="log4net.Layout.PatternLayout">
                <param name="ConversionPattern" value="%date{yyyy-MM-dd HH:mm:ss.fff} %-8p %m%n" />
            </layout>
            <!-- 此模式输出的级别范围 -->
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="WARN" />
                <levelMax value="WARN" />
            </filter>
        </appender>

        <appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender">
            <param name= "File" value= "Logs"/>
            <param name= "AppendToFile" value= "true"/>
            <param name= "MaxSizeRollBackups" value= "10"/>
            <!-- 能保存的文件最大值 -->
            <param name="MaximumFileSize" value="1MB" />
            <param name= "StaticLogFileName" value= "false"/>
            <param name= "DatePattern" value= "yyyy-MM-dd&quot;_Error.log&quot;"/>
            <param name= "RollingStyle" value= "Date"/>
            <layout type="log4net.Layout.PatternLayout">
                <param name="ConversionPattern" value="%date{yyyy-MM-dd HH:mm:ss.fff} %-8p %m%n" />
            </layout>
            <!-- 此模式输出的级别范围 -->
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="ERROR" />
                <levelMax value="ERROR" />
            </filter>
        </appender>

        <appender name="FatalAppender" type="log4net.Appender.RollingFileAppender">
            <param name= "File" value= "Logs"/>
            <param name= "AppendToFile" value= "true"/>
            <param name= "MaxSizeRollBackups" value= "10"/>
            <param name= "StaticLogFileName" value= "false"/>
            <param name= "DatePattern" value= "yyyy-MM-dd&quot;_Fatal.log&quot;"/>
            <param name= "RollingStyle" value= "Date"/>
            <layout type="log4net.Layout.PatternLayout">
                <param name="ConversionPattern" value="%date{yyyy-MM-dd HH:mm:ss.fff} %-8p %m%n" />
            </layout>
            <!-- 此模式输出的级别范围 -->
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="FATAL" />
                <levelMax value="FATAL" />
            </filter>
        </appender>

        <appender name="DebugAppender" type="log4net.Appender.RollingFileAppender">
            <param name= "File" value= "Logs"/>
            <param name= "AppendToFile" value= "true"/>
            <param name= "MaxSizeRollBackups" value= "10"/>
            <param name= "StaticLogFileName" value= "false"/>
            <param name= "DatePattern" value= "yyyy-MM-dd&quot;_Debug.log&quot;"/>
            <param name= "RollingStyle" value= "Date"/>
            <layout type="log4net.Layout.PatternLayout">
                <param name="ConversionPattern" value="%date{yyyy-MM-dd HH:mm:ss.fff} %-8p %m%n" />
            </layout>
            <!-- 此模式输出的级别范围 -->
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="DEBUG" />
                <levelMax value="DEBUG" />
            </filter>
        </appender>

    </log4net>
</configuration>

效果如下:


 

1         static void Main(string[] args)
2         {
3             LogHelper.WriteDebugLog("1234444445");
4         }
  • 6.经验之谈:不要把项目名称起为log4net,或任何数字在中间的名称,否则引入log4net.dll的时候就会直接报错
  • **7.当运行正常没有创建日志文件或者log =
    LogManager.GetLogger(typeof(AppLog))中log对象字段值为false时,右击log4net.config选择属性**–>高级把复制到项目的值改为始终复制**
  •  8  类库项目中好像不能实现此打印日志功能,

图片 5

 

Demo下载:

 

发表评论