欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#使用log4net的3種調(diào)用方法

 更新時(shí)間:2024年03月01日 09:04:32   作者:summer_top  
log4net是一個(gè)用于記錄日志的開(kāi)源框架,它是C#中最常用的日志記錄工具之一,本文給大家介紹了C#使用log4net的3種調(diào)用方法,通過(guò)圖文和代碼給大家講解的非常詳細(xì),需要的朋友可以參考下

第一步:下載log4net

右鍵項(xiàng)目引用,進(jìn)入管理NuGet包。

搜索log4net,下載安裝。

第二步:創(chuàng)建LogHelper類(lèi)

public class LogHelper
    {
        private LogHelper()
        {
 
        }
        public static readonly log4net.ILog loginfo = log4net.LogManager.GetLogger("loginfo");
        public static readonly log4net.ILog logerror = log4net.LogManager.GetLogger("logerror");
        public static void SetConfig()
        {
            log4net.Config.XmlConfigurator.Configure();
        }
        public static void SetConfig(FileInfo configFile)
        {
            log4net.Config.XmlConfigurator.Configure(configFile);
        }
        public static void WriteLog(string info)
        {
            if (loginfo.IsInfoEnabled)
            {
                loginfo.Info(info);
            }
        }
        public static void WriteLog(string info, Exception se)
        {
            if (logerror.IsErrorEnabled)
            {
                logerror.Error(info, se);
            }
        }
    }

第三步:配置Log4Net并輸出日志,下面介紹三種調(diào)用方法

方法一:在已有App.config中配置Log4Net

App.config代碼如下。

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
 
  <configSections>
   <!-- log4net的定義 -->
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
  </configSections>
  
  <log4net>
    <logger name="logerror">
      <level value="ERROR" />
      <appender-ref ref="ErrorAppender" />
    </logger>
    <logger name="loginfo">
      <level value="INFO" />
      <appender-ref ref="InfoAppender" />
    </logger>
 
    <appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="Log\\LogError\\" />
      <param name="AppendToFile" value="true" />
      <param name="MaxSizeRollBackups" value="100" />
      <param name="MaxFileSize" value="10240" />
      <param name="StaticLogFileName" value="false" />
      <param name="DatePattern" value="yyyyMMdd&quot;.txt&quot;" />
      <param name="RollingStyle" value="Date" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%n異常時(shí)間:%d %n異常級(jí)別:%-5p%n異常內(nèi)容:%m%n" />
      </layout>
     <!--&lt; &gt; = <> %n = 回車(chē)-->
    </appender>
    <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="Log\\LogInfo\\" />
      <param name="AppendToFile" value="true" />
      <param name="MaxFileSize" value="10240" />
      <param name="MaxSizeRollBackups" value="100" />
      <param name="StaticLogFileName" value="false" />
      <param name="DatePattern" value="yyyyMMdd&quot;.txt&quot;" />
      <param name="RollingStyle" value="Date" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="日志時(shí)間:%d %n日志級(jí)別:%-5p  %n日志內(nèi)容:%m%n%n" />
      </layout>
    </appender>
  </log4net>
  
</configuration>

在項(xiàng)目的 AssemblyInfo.cs 文件中注冊(cè)Config文件

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

主程序調(diào)用:

public MainWindow()
        {
            InitializeComponent();
            LogHelper.WriteLog("我是LogHelper日志輸出:在已有App.config中配置Log4Net");
        }

運(yùn)行結(jié)果:

方法二:項(xiàng)目中創(chuàng)建新的log4net.config文件

首先右鍵項(xiàng)目,添加新建項(xiàng),添加新的應(yīng)用程序配置文件log4net.config,log4net配置信息和方法一相同。

log4net.config代碼如下:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <log4net>
    <logger name="logerror">
      <level value="ERROR" />
      <appender-ref ref="ErrorAppender" />
    </logger>
    <logger name="loginfo">
      <level value="INFO" />
      <appender-ref ref="InfoAppender" />
    </logger>
    <appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="Log\\LogError\\" />
      <param name="AppendToFile" value="true" />
      <param name="MaxSizeRollBackups" value="100" />
      <param name="MaxFileSize" value="10240" />
      <param name="StaticLogFileName" value="false" />
      <param name="DatePattern" value="yyyyMMdd&quot;.txt&quot;" />
      <param name="RollingStyle" value="Date" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%n異常時(shí)間:%d %n異常級(jí)別:%-5p%n異常內(nèi)容:%m%n" />
      </layout>
      <!--&lt; &gt; = <> %n = 回車(chē)-->
    </appender>
    <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="Log\\LogInfo\\" />
      <param name="AppendToFile" value="true" />
      <param name="MaxFileSize" value="10240" />
      <param name="MaxSizeRollBackups" value="100" />
      <param name="StaticLogFileName" value="false" />
      <param name="DatePattern" value="yyyyMMdd&quot;.txt&quot;" />
      <param name="RollingStyle" value="Date" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="日志時(shí)間:%d %n日志級(jí)別:%-5p  %n日志內(nèi)容:%m%n%n" />
      </layout>
    </appender>
  </log4net>
</configuration>

再設(shè)置log4net.config的屬性:將 “復(fù)制到輸出目錄” 的值改為 如果較新則復(fù)制。

然后在項(xiàng)目的 AssemblyInfo.cs 文件中注冊(cè)Config文件:

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

ConfigFile: 配置文件名和路徑,包括擴(kuò)展名,文件相對(duì)于程序的根目錄。

ConfigFileExtension:配置文件的后綴名,缺省默認(rèn)時(shí)'config',此屬性不可和ConfigFile屬性公用。

最后主程序調(diào)用:

public MainWindow()
        {
            InitializeComponent();
            LogHelper.WriteLog("我是LogHelper日志輸出:在項(xiàng)目中創(chuàng)建新的log4net.config文件");
        }

運(yùn)行結(jié)果:

方法三:顯示調(diào)用配置文件

首先創(chuàng)建log4net.xml配置文件,代碼如下。

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <log4net>
    <logger name="logerror">
      <level value="ERROR" />
      <appender-ref ref="ErrorAppender" />
    </logger>
    <logger name="loginfo">
      <level value="INFO" />
      <appender-ref ref="InfoAppender" />
    </logger>
    <appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="Log\\LogError\\" />
      <param name="AppendToFile" value="true" />
      <param name="MaxSizeRollBackups" value="100" />
      <param name="MaxFileSize" value="10240" />
      <param name="StaticLogFileName" value="false" />
      <param name="DatePattern" value="yyyyMMdd&quot;.txt&quot;" />
      <param name="RollingStyle" value="Date" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="%n異常時(shí)間:%d %n異常級(jí)別:%-5p%n異常內(nèi)容:%m%n" />
      </layout>
      <!--&lt; &gt; = <> %n = 回車(chē)-->
    </appender>
    <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="Log\\LogInfo\\" />
      <param name="AppendToFile" value="true" />
      <param name="MaxFileSize" value="10240" />
      <param name="MaxSizeRollBackups" value="100" />
      <param name="StaticLogFileName" value="false" />
      <param name="DatePattern" value="yyyyMMdd&quot;.txt&quot;" />
      <param name="RollingStyle" value="Date" />
      <layout type="log4net.Layout.PatternLayout">
        <param name="ConversionPattern" value="日志時(shí)間:%d %n日志級(jí)別:%-5p  %n日志內(nèi)容:%m%n%n" />
      </layout>
    </appender>
  </log4net>
</configuration>

使用LogHelper類(lèi)中SetConfig(FileInfo configFile)方法配置log4net。 log4net.Config.XmlConfigurator.Configure(FileInfo(path)),path為log4net.xml的全路徑。

主程序調(diào)用:

 public MainWindow()
        {
            InitializeComponent();
            LogHelper.SetConfig(new FileInfo("D:\\Log4NetDemo\\log4net.xml"));
            LogHelper.WriteLog("我是LogHelper日志輸出:顯示調(diào)用");
        }

運(yùn)行結(jié)果:

三種調(diào)用方法,都能夠正常打印日志。

以上就是C#使用log4net的3種調(diào)用方法的詳細(xì)內(nèi)容,更多關(guān)于C#使用log4net的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論