log4NET学习

  1  毕业一年了,想起刚毕业那会所做的事 有点好笑。。。。

      由于项目经理之前是用VB的,刚好要把项目的代码全转为C#,所以碰上了这个很好的机会,但工资低得可怜,抱着刚毕业主要是学习为主的心态,开始了我的职业生涯。

      首先是从C#里最基本的模块做起,读取INI 读取XML,日志处理,数据库操作等等,这差不多做了一二个月吧,

    其它这些基本的东西网上到处是,当时就没想过这么多,只是找过一些思路。真可谓 此情可待成追忆,只是当时已惘然。

  如果从网上找这些对应的开源,不到一周就基本上能搞好了,真是浪费人力,浪费工资。

      后面就把GIS里的模块用C#写了一遍,这对换工作是极有用的。

 基本的数据管理,配置管理,视图操作,查询模块,分析,统计等模块。

     日志处理并不是一个很简单的事情,当你有了Log4NET后就大可不必担心了,来看看如何快速的使用它吧。。

首先需要配置相关的配置文件App.config或Web.config,顾名思义普通应用的配置文件

为App.config,asp.net的配置文件为Web.config。有关log的配置如下:

<configuration>

   <configSections>

       <!-- log4net的定义 -->

         <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />

   </configSections>

   <log4net>

   <!-- Console部分log输出格式的设定 -->

         <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">

             <layout type="log4net.Layout.PatternLayout">

                 <conversionPattern value="%date [%thread] %-5level %logger %ndc - %message%newline" />

             </layout>

         </appender>

   <!-- 日志文件部分log输出格式的设定 -->

         <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">

             <file value="c:\a.log" />

             <appendToFile value="true" />

             <maxSizeRollBackups value="10" />

             <maximumFileSize value="1MB" />

             <rollingStyle value="Size" />

             <staticLogFileName value="true" />

             <layout type="log4net.Layout.PatternLayout">

                 <header value="[Header] " />

                 <footer value="[Footer] " />

                 <ConversionPattern value="%date [%thread] %-5level %logger [%ndc] - %message%newline" />

             </layout>

         </appender>

  

   <!-- Setup the root category, add the appenders and set the default level -->

         <root>

             <level value="ALL" />

             <appender-ref ref="ConsoleAppender" />

             <appender-ref ref="RollingLogFileAppender" />

         </root>

     </log4net>

</configuration>

 

 

其次在项目的AssemblyInfo.cs里面加上[assembly: log4net.Config.XmlConfigurator()],这样项目工程和log4net就

建立了关联。

备注:[assembly: log4net.Config.DOMConfigurator()]这句话的意思是log4net系统会自动寻找配置文件App.config或Web.config

从而获得并加载其中的配置信息。如果想log4net随时监视配置文件以便重新加载的话就要这样写:

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

最后就是源文件中的使用了。

添加log4net的引用using log4net;

同时在相关的类中定义log变量如

   protected static readonly log4net.ILog mLog =

    LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

log的具体操作,Form1中加入了:

如mLog.Error("ha ha log4NET");

 

 

找下你的C盘,里面的 c:\a.log吧

[Header] 2009-08-21 09:31:52,140 [10] ERROR Test.Form1 [(null)] - ha ha log4NET

 

 

怎么样?很方便吧,,之前写日志处理都 不知道花了多少时间,太爽了。。

原文地址:https://www.cnblogs.com/lhjhl/p/1551171.html