VS2012 C#使用/配置Log4Net


最近悟出來一個道理,在這兒分享給大家:學歷代表你的過去,能力代表你的現在,學習代表你的將來。

十年河東十年河西,莫欺少年窮

學無止境,精益求精  

本節探討如何在VS2012中使用Log4Net

1、首先在項目中添加Nuget程序包...

 2、然后在NuGet窗體中搜索Log4Net,然后點擊安裝<安裝過程可能會持續幾分鍾,請耐心等待>

3、在項目中添加一個Config文件,並命名為:Log4Net.config

截圖中配置的XML代碼如下:

<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="&lt;HR COLOR=red&gt;%n異常時間:%d [%t] &lt;BR&gt;%n異常級別:%-5p &#xD;&#xA;   &lt;BR&gt;%n異 常 類:%c [%x] &lt;BR&gt;%n%m &lt;BR&gt;%n &lt;HR Size=1&gt;" />
    </layout>
  </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="&lt;HR COLOR=blue&gt;%n日志時間:%d [%t] &lt;BR&gt;%n日志級別:%-5p &#xD;&#xA;   &lt;BR&gt;%n日 志 類:%c [%x] &lt;BR&gt;%n%m &lt;BR&gt;%n &lt;HR Size=1&gt;" />
    </layout>
  </appender>
</log4net>

最后在項目的 AssemblyInfo.cs 文件中注冊Config文件,如下:

//為項目注冊Log4Net.config配置文件
[assembly: log4net.Config.DOMConfigurator(ConfigFile = "Log4Net.config", Watch = true)]

最后,添加日志類:

 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.DOMConfigurator.Configure();
        }

        public static void SetConfig(FileInfo configFile)
        {
            log4net.Config.DOMConfigurator.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);
            }
        }
    }

好了,到了這里,准備工作也就完成了,下面我們就開始測試下吧<為了簡單,直接在日志文件中寫一句話>

首先引用:using log4net;

然后:

    public partial class index : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            LogHelper.WriteLog("陳卧龍是個大壞蛋");
        }
    }

最后,我們在項目中顯示所有文件,你會發現有個Log文件夾,如下:

我們打開LogInfo文件夾下20161220.txt便會看到我們打印的信息

當然,您的代碼也可以這樣寫:

        protected void Page_Load(object sender, EventArgs e)
        {
            try
            {
                //todo
            }
            catch(Exception ex)
            {
                LogHelper.WriteLog("被除數為零,呃呃呃,小學數學沒學好!", ex);
            }
        }

在todo過程中一旦發生異常就會執行Catch()語段,這時會在LogError文件夾中的文件中寫入日志。

 好了,Log4Net還有一些用法,在此不作舉例了!

        protected void Page_Load(object sender, EventArgs e)
        {
            try
            {
                //todo
                LogHelper.loginfo.Warn("警告消息");
                LogHelper.logerror.Warn("錯誤警告信息");
            }
            catch(Exception ex)
            {
                LogHelper.WriteLog("被除數為零,呃呃呃,小學數學沒學好!", ex);
            }
        }

等等吧!

如果您覺得還可以,就點個贊吧!謝謝!

@陳卧龍的博客

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM