欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

log4net怎么用-創(chuàng)新互聯(lián)

這篇文章主要介紹log4net怎么用,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!

成都創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供鹿邑網(wǎng)站建設(shè)、鹿邑做網(wǎng)站、鹿邑網(wǎng)站設(shè)計、鹿邑網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、鹿邑企業(yè)網(wǎng)站模板建站服務(wù),十多年鹿邑做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。

程序中只需要引用log4net.dll文件即可

配置的引用

log4net.Config.XmlConfigurator.Configure();

首先添加以上代碼。

CS程序:在Main方法中添加;

BS程序:Application_Start方法中添加;

或是兩者都可以在AssemblyInfo.cs(Properties中)文件里添加以下的語句:

//設(shè)置獨立配置文件,log4net.config
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config" , Watch = true )]
//或是默認(rèn)的配置文件
[assembly: log4net.Config.XmlConfigurator(Watch = true )] (配置在web.config文件中)

詳細(xì)配置

log4net,可以把日志輸出到控制臺程序,文件,數(shù)據(jù)庫、郵件,下面貼出四個輸出的配置代碼,其余如window日志等輸出不做闡述。

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
 <!--首先加入configSections配置節(jié)點-->
 <configSections>
  <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
 </configSections>
 <log4net><br>
  <root>
   <!--(高) OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL (低) -->
   <!--限制日志記錄級別-->
   <level value="all" />
   <!--將日志輸出到文件-->
   <appender-ref ref="FileAppender"/>
   <!--將日志輸出到應(yīng)用程序控制臺-->
   <appender-ref ref="ConsoleAppender"/>
   <!--將日志寫到郵件中-->
   <!--<appender-ref ref="LogSmtpAppender"/>-->
   <!--將日志記錄到數(shù)據(jù)庫中??梢圆捎肧QL和存儲過程兩種方式-->
   <appender-ref ref="AdoNetAppender"/>
   <!--可以同時設(shè)置多個輸出對象,沒用到可以注釋-->
   <!--將日志寫到local syslog service (僅用于UNIX環(huán)境下)。-->
   <!--<appender-ref ref="LocalSyslogAppender"/>-->
  </root><br>
  <!--發(fā)郵件-->
  <appender name="LogSmtpAppender" type="log4net.Appender.SmtpAppender">
   <authentication value="Basic" />
   <!--接受郵件的郵箱-->
   <to value="7778888@qq.com" />
   <!--發(fā)送郵件的郵箱-->
   <from value="123456@126.com" />
   <!--發(fā)送郵件的郵箱-->
   <username value="123456@126.com" />
   <!--發(fā)送郵件的郵箱密碼-->
   <password value="123456" />
   <!--標(biāo)題-->
   <subject value="XXX應(yīng)用錯誤日志消息" />
   <!--smtp.qq.com-->
   <smtpHost value="smtp.126.com" />
   <bufferSize value="2048" />
   <!--超長部分是否丟棄-->
   <lossy value="true" />
   <!--日志級別 大于 WARN 的才發(fā)郵件-->
   <evaluator type="log4net.Core.LevelEvaluator">
    <threshold value="ERROR"/>
   </evaluator>
   <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value=" %level :: %message %newlineLogger: %logger%newline Date: %date%newline" />
   </layout>
  </appender><br>
  <!-- 控制臺日志 -->
  <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
   <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%n%d{yyyy-MM-dd HH:mm:ss} %m%n" />
   </layout>
   <!--指定范圍內(nèi)的等級才可以被記錄-->
   <!--<filter type="log4net.Filter.LevelRangeFilter">
    <param name="LevelMin" value="Info" />
    <param name="LevelMax" value="Fatal" />
   </filter>-->
  </appender >
 
  <!--指定日記記錄方式,以滾動文件的方式(文件記錄)-->
  <appender name="FileAppender" type="log4net.Appender.RollingFileAppender">
   <!--日志路徑-->
   <param name= "File" value= "log/"/>
   <!--是否是向文件中追加日志-->
   <param name= "AppendToFile" value= "true"/>
   <!--log保留天數(shù)-->
   <param name= "MaxSizeRollBackups" value= "10"/>
   <!--每個文件較大1M-->
   <param name="maximumFileSize" value="1MB" />
   <!--日志文件名是否是固定不變的-->
   <param name= "StaticLogFileName" value= "false"/>
   <!--日志文件名格式為:2008-08-31.log-->
   <param name= "DatePattern" value= "yyyy-MM-dd".log""/>
   <!--日志根據(jù)日期滾動-->
   <param name= "RollingStyle" value= "Date"/>
   <!--布局-->
   <layout type="log4net.Layout.PatternLayout">
    <param name="ConversionPattern" value="%n記錄時間:%d{yyyy-MM-dd HH:mm:ss} 線程名:[%t] 級別:%p 類名:%c 信息:%m%n" />
    <param name="Header" value="----------------------------------------------------------- "/>
   </layout>
  </appender><br>
  <!--數(shù)據(jù)庫日記-->
  <appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">
   <!--設(shè)置為1方便查看結(jié)果,處于性能考慮這里的值應(yīng)該略大一點,官方默認(rèn)值是100,BufferSize為緩沖區(qū)大小,只有日志記錄超設(shè)定值才會一塊寫入到數(shù)據(jù)庫-->
   <bufferSize value="1" />
   <!--sqlserver 引用-->
   <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
   <!--連接數(shù)據(jù)庫字符串-->
   <connectionString value="data source=.;initial catalog=test;integrated security=false;persist security info=True;User ID=sa;Password=sqlserver;" />
   <!--插入到表Log-->
   <commandText value="INSERT INTO LogTest ([Date],[Level],[Logger],[Message],[Exception],[Description],[ObjType]) VALUES (@log_date,@log_level, @logger, @message, @exception,@Description,@ObjType)" />
   <!--所有參數(shù)-->
   <parameter>
    <parameterName value="@log_date" />
    <dbType value="DateTime" />
    <layout type="log4net.Layout.RawTimeStampLayout" />
   </parameter>
   <parameter>
    <parameterName value="@log_level" />
    <dbType value="String" />
    <size value="50" />
    <layout type="log4net.Layout.PatternLayout">
     <conversionPattern value="%level" />
    </layout>
   </parameter>
   <!--類所在位置-->
   <parameter>
    <parameterName value="@logger" />
    <dbType value="String" />
    <size value="255" />
    <layout type="log4net.Layout.PatternLayout">
     <conversionPattern value="%logger" />
    </layout>
   </parameter>
   <parameter>
    <parameterName value="@message" />
    <dbType value="String" />
    <size value="4000" />
    <layout type="log4net.Layout.PatternLayout">
     <conversionPattern value="%message" />
    </layout>
   </parameter>
   <parameter>
    <parameterName value="@exception" />
    <dbType value="String" />
    <size value="2000" />
    <layout type="log4net.Layout.ExceptionLayout" />
   </parameter>
   <!--自定義輸入字段-->
   <parameter>
    <parameterName value = "@Description"/>
    <dbType value = "String"/>
    <size value = "50"/>
    <layout type = "log4_Test.Log4netExpand.ExpandLayout">
    <conversionPattern value = "%property{Description}"/>
    </layout>
   </parameter>
   <parameter>
    <parameterName value = "@ObjType"/>
    <dbType value = "String"/>
    <size value = "50"/>
    <layout type = "log4_Test.Log4netExpand.ExpandLayout">
     <conversionPattern value = "%property{ObjType}"/>
    </layout>
   </parameter>
  </appender>
 
 </log4net>
</configuration>

 <layout type = "log4_Test.Log4netExpand.ExpandLayout"> 中的log4_Test.Log4netExpand 為命名空間

布局、格式字符說明:

%p:輸出日志信息的優(yōu)先級,即DEBUG,INFO,WARN,ERROR,F(xiàn)ATAL。
%d:輸出日志時間點的日期或時間,默認(rèn)格式為ISO8601,也可以在其后指定格式,如:%d{yyyy/MM/dd HH:mm:ss,SSS}。
%r:輸出自應(yīng)用程序啟動到輸出該log信息耗費的毫秒數(shù)。
%t:輸出產(chǎn)生該日志事件的線程名。
%l:輸出日志事件的發(fā)生位置,相當(dāng)于%c.%M(%F:%L)的組合,包括類全名、方法、文件名以及在代碼中的行數(shù)。例如:test.TestLog4j.main(TestLog4j.java:10)。
%c:輸出日志信息所屬的類目,通常就是所在類的全名。
%M:輸出產(chǎn)生日志信息的方法名。
%F:輸出日志消息產(chǎn)生時所在的文件名稱。
%L::輸出代碼中的行號。
%m::輸出代碼中指定的具體日志信息。
%n:輸出一個回車換行符,Windows平臺為"\r\n",Unix平臺為"\n"。
%x:輸出和當(dāng)前線程相關(guān)聯(lián)的NDC(嵌套診斷環(huán)境),尤其用到像java servlets這樣的多客戶多線程的應(yīng)用中。
%%:輸出一個"%"字符。
另外,還可以在%與格式字符之間加上修飾符來控制其最小長度、較大長度、和文本的對齊方式。如:
1)%20c:指定輸出category的名稱,最小的長度是20,如果category的名稱長度小于20的話,默認(rèn)的情況下右對齊。
2)%-20c:"-"號表示左對齊。
3)%.30c:指定輸出category的名稱,較大的長度是30,如果category的名稱長度大于30的話,就會將左邊多出的字符截掉,但小于30的話也不會補空格。

 自定義數(shù)據(jù)庫插入字段(源自網(wǎng)絡(luò)收集、整理)

1.先定義一個LogData類:

namespace log4_Test.Log4netExpand
{
  public class LogData
  {
    /// <summary>
    /// 日志描述信息
    /// </summary>
    public string Description { get; set; }
    /// <summary>
    /// 日志描述信息
    /// </summary>
    public string ObjType { get; set; }
  }
}

2.Layout擴展類

namespace log4_Test.Log4netExpand
{
  public class ExpandLayout : PatternLayout
  {
    public ExpandLayout()
    {
       this.AddConverter("property", typeof(MyMessagePatternConverter));
    }
  }
}

3.MyMessagePatternConverter 類

namespace log4_Test.Log4netExpand
{
  public class MyMessagePatternConverter: PatternLayoutConverter
  {
    protected override void Convert(System.IO.TextWriter writer, log4net.Core.LoggingEvent loggingEvent)
    {

      if (Option != null)
      {

        // Write the value for the specified key

        WriteObject(writer, loggingEvent.Repository, LookupProperty(Option, loggingEvent));

      }
      else
      {

        // Write all the key value pairs

        WriteDictionary(writer, loggingEvent.Repository, loggingEvent.GetProperties());

      }
    }
    /// <summary>
    /// 通過反射獲取傳入的日志對象的某個屬性的值
    /// </summary>
    /// <param name="property"></param>
    /// <returns></returns>
    private object LookupProperty(string property, log4net.Core.LoggingEvent loggingEvent)
    {
      object propertyValue = string.Empty;
      PropertyInfo propertyInfo = loggingEvent.MessageObject.GetType().GetProperty(property);
      if (propertyInfo != null)
      {
        propertyValue = propertyInfo.GetValue(loggingEvent.MessageObject, null);
      }
      return propertyValue;

    }
  }
}

4.使用代碼如下:

public class Program
  {
    static void Main(string[] args)
    {
      
      //能看到是那個類輸出
      ILog logger = log4net.LogManager.GetLogger(typeof(Program));

      logger.Info(new LogData { Description="123", ObjType="123"})
     
      logger.Info("消息11111111111111111111111111111");
      logger.Warn("警告");
      logger.Error("異常");
      logger.Fatal("錯誤");
     
    }
  }

以上是“l(fā)og4net怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

文章題目:log4net怎么用-創(chuàng)新互聯(lián)
轉(zhuǎn)載注明:http://aaarwkj.com/article28/dshhjp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機、定制開發(fā)、小程序開發(fā)、響應(yīng)式網(wǎng)站、Google微信小程序

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設(shè)
国产一区二区三区性色| 久久久久久久精品久久| 亚洲精品成人一区二区| 视频一区二区日韩不卡| 免费人成视频在线观看不卡| 婷婷网色偷偷亚洲男人| 欧美黄片不用下载在线观看| 国产精品中文字幕日韩在线| 好色人妻在线播放中文字幕| 国产精品久久久久久久亚洲| 国产一区二区毛多内射| 日韩精品毛片精品一区到三区| 自拍偷拍亚洲精品第一页| 久久97精品人人做人人爽| 中文字幕乱码日韩一区| 国产成人激情自拍视频在线观看| 人妻系列日本在线播放| 亚洲国产第一尤物视频| 免费人成在线观看网站免费观看| 日本激情诱惑免费在线播放| 白浆视频在线免费观看| 国产精品神马午夜福利| 欧美成人免费做真爱高潮| 亚洲青青草原自拍偷拍| 国产成人91精品免费看片| 日本亚洲欧美男人的天堂| 午夜看片福利欧美熟女| 精品人妻二区中文字幕| 国产在线精品不卡一区| 亚洲综合色一区二区三区四区| 日本午夜福利视频在线观看| 日韩高清一级黄色大片网站| 另类国产人妖免费视频网站大全| 欧美中文字幕精在线不卡| 99久久精品人妻少妇一| 美女露脸口爆吞精视频| 国产高清精品在线一区| 青春草草视频在线观看| 欧美看黄网站在线观看| 亚洲激情久热中文字幕| 国产成人在线免费短视频|