1. 程式人生 > >log4Net輔助類

log4Net輔助類

section debug.log .config ext actor oot HA ID com

public class Log
    {
        private ILog logger;
        public Log(ILog log)
        {
            this.logger = log;
        }
        public void Debug(object message)
        {
            this.logger.Debug(message);
        }
        public void Error(object message)
        {
            this
.logger.Error(message); } public void Info(object message) { this.logger.Info(message); } public void Warn(object message) { this.logger.Warn(message); } }
 public class LogFactory
    {
        static LogFactory()
        {
            FileInfo configFile 
= new FileInfo(HttpContext.Current.Server.MapPath("/Configs/log4net.config")); log4net.Config.XmlConfigurator.Configure(configFile); } public static Log GetLogger(Type type) { return new Log(LogManager.GetLogger(type)); } public static Log GetLogger(string
str) { return new Log(LogManager.GetLogger(str)); } }

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

  <log4net>
    <!--根配置-->
    <root>
      <!--日誌級別:可選值: ERROR > WARN > INFO > DEBUG -->
      <level value="ERROR"/>
      <level value="WARN"/>
      <level value="INFO"/>
      <level value="DEBUG"/>
      <appender-ref ref="ErrorLog" />
      <appender-ref ref="WarnLog" />
      <appender-ref ref="InfoLog" />
      <appender-ref ref="DebugLog" />
    </root>
    <!-- 錯誤 Error.log-->
    <appender name="ErrorLog" type="log4net.Appender.RollingFileAppender">
      <!--目錄路徑,可以是相對路徑或絕對路徑-->
      <param name="File" value="D:\NFine_log"/>
      <!--文件名,按日期生成文件夾-->
      <param name="DatePattern" value="/yyyy-MM-dd/&quot;Error.log&quot;"/>
      <!--追加到文件-->
      <appendToFile value="true"/>
      <!--創建日誌文件的方式,可選值:Date[日期],文件大小[Size],混合[Composite]-->
      <rollingStyle value="Composite"/>
      <!--寫到一個文件-->
      <staticLogFileName value="false"/>
      <!--單個文件大小。單位:KB|MB|GB-->
      <maximumFileSize value="200MB"/>
      <!--最多保留的文件數,設為"-1"則不限-->
      <maxSizeRollBackups value="-1"/>
      <!--日誌格式-->
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%message"/>
      </layout>
      <filter type="log4net.Filter.LevelRangeFilter">
        <param name="LevelMin" value="ERROR" />
        <param name="LevelMax" value="ERROR" />
      </filter>
    </appender>

    <!-- 警告 Warn.log-->
    <appender name="WarnLog" type="log4net.Appender.RollingFileAppender">
      <!--目錄路徑,可以是相對路徑或絕對路徑-->
      <param name="File" value="D:\NFine_log"/>
      <!--文件名,按日期生成文件夾-->
      <param name="DatePattern" value="/yyyy-MM-dd/&quot;Warn.log&quot;"/>
      <!--追加到文件-->
      <appendToFile value="true"/>
      <!--創建日誌文件的方式,可選值:Date[日期],文件大小[Size],混合[Composite]-->
      <rollingStyle value="Composite"/>
      <!--寫到一個文件-->
      <staticLogFileName value="false"/>
      <!--單個文件大小。單位:KB|MB|GB-->
      <maximumFileSize value="200MB"/>
      <!--最多保留的文件數,設為"-1"則不限-->
      <maxSizeRollBackups value="-1"/>
      <!--日誌格式-->
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%message"/>
      </layout>
      <filter type="log4net.Filter.LevelRangeFilter">
        <param name="LevelMin" value="WARN" />
        <param name="LevelMax" value="WARN" />
      </filter>
    </appender>

    <!-- 信息 Info.log-->
    <appender name="InfoLog" type="log4net.Appender.RollingFileAppender">
      <!--目錄路徑,可以是相對路徑或絕對路徑-->
      <param name="File" value="D:\NFine_log"/>
      <!--文件名,按日期生成文件夾-->
      <param name="DatePattern" value="/yyyy-MM-dd/&quot;Info.log&quot;"/>
      <!--追加到文件-->
      <appendToFile value="true"/>
      <!--創建日誌文件的方式,可選值:Date[日期],文件大小[Size],混合[Composite]-->
      <rollingStyle value="Composite"/>
      <!--寫到一個文件-->
      <staticLogFileName value="false"/>
      <!--單個文件大小。單位:KB|MB|GB-->
      <maximumFileSize value="200MB"/>
      <!--最多保留的文件數,設為"-1"則不限-->
      <maxSizeRollBackups value="-1"/>
      <!--日誌格式-->
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%message"/>
      </layout>
      <filter type="log4net.Filter.LevelRangeFilter">
        <param name="LevelMin" value="INFO" />
        <param name="LevelMax" value="INFO" />
      </filter>
    </appender>

    <!-- 調試 Debug.log-->
    <appender name="DebugLog" type="log4net.Appender.RollingFileAppender">
      <!--目錄路徑,可以是相對路徑或絕對路徑-->
      <param name="File" value="D:\NFine_log"/>
      <!--文件名,按日期生成文件夾-->
      <param name="DatePattern" value="/yyyy-MM-dd/&quot;Debug.log&quot;"/>
      <!--追加到文件-->
      <appendToFile value="true"/>
      <!--創建日誌文件的方式,可選值:Date[日期],文件大小[Size],混合[Composite]-->
      <rollingStyle value="Composite"/>
      <!--寫到一個文件-->
      <staticLogFileName value="false"/>
      <!--單個文件大小。單位:KB|MB|GB-->
      <maximumFileSize value="200MB"/>
      <!--最多保留的文件數,設為"-1"則不限-->
      <maxSizeRollBackups value="-1"/>
      <!--日誌格式-->
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%message"/>
      </layout>
      <filter type="log4net.Filter.LevelRangeFilter">
        <param name="LevelMin" value="DEBUG" />
        <param name="LevelMax" value="DEBUG" />
      </filter>
    </appender>


  </log4net>
  <startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
  </startup>
</configuration>

log4Net輔助類