国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開APP
userphoto
未登錄

開通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開通VIP
ASP.NET中使用Apache log4net - .NET2.0 成功在于總結(jié) - 博...
 
 log4net是Apache log4j的.net版,是一套XML配置型的日志引擎,正好最近有個(gè)程序需要日志系統(tǒng),為了整合方便,就決定研究一下。感謝郝偉推薦。

 log4net系統(tǒng)劃分了7個(gè)日志等級,如設(shè)置為"WARN",則DEBUG,INFO不會被記錄。如下:

1. ALL

2. DEBUG

3. INFO

4. WARN

5. ERROR

6. FATAL

7. OFF

Creating the Sample Application

 

Step 1: 下載log4net

去logging.apache.org/log4net,來獲取他們的最近版,在例子里我用的是incubating-log4net-1.2.9-beta.zip,期待正式版。

 

Step 2: 創(chuàng)建 ASP.NET Web 應(yīng)用程序

    創(chuàng)建這個(gè)就不多說了,在log4net-1.2.0-beta8\bin\net如圖。找到對應(yīng)的dll,添加到引用里。有的版本沒有編譯好的dll,那就自己編一下吧,用.NET V1.0的那個(gè)版本轉(zhuǎn)換成1.1或2.0的。我覺得這不是工作失誤,是故意的。他們玩java玩慣了的人好多都是這樣。

Configuring the Sample Application

 

Step 3: 添加Assembly信息

打開AssemblyInfo.cs文件,添加:

[assembly: log4net.Config.DOMConfigurator()]
這句話的意思是log4net系統(tǒng)會自動尋找配置文件Web.config從而獲得并加載其中的配置信息。如果想log4net隨時(shí)監(jiān)視配置文件以便重新加載的話就
稍微麻煩點(diǎn)了要這樣寫:


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

Step 4: 添加配置信息

要編輯Web.config文件了,真是每次看見它都有驚喜啊。找到configuration標(biāo)簽,configSections要緊挨著寫到它下面(一點(diǎn)都不替別人考慮,要在有一個(gè)也跟他一樣霸道怎么辦?那就單寫個(gè)它的日志配置文件吧!我估計(jì)APACHE他們就是這么想的)??纯蠢影桑?/p>


<?xml version="1.0" encoding="utf-8" ?>

<configuration>

 <configSections>

    <section name="log4net"

             type="log4net.Config.Log4NetConfigurationSectionHandler, log4net-net-1.0"

    />

 </configSections>

 

 <!-- This section contains the log4net configuration settings -->

 <log4net>

    <!-- Define some output appenders -->

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

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

        <param name="ConversionPattern" value="%d [%t] %-5p %c [%x] <%X{auth}> - %m%n" />

      </layout>

    </appender>

    <!-- RollingFileAppender looks after rolling over files by size or date -->

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

      <param name="File" value="C:\\log\\RollingLogHelloWorld.log" />

      <param name="AppendToFile" value="true" />

      <param name="MaxSizeRollBackups" value="10" />

      <param name="MaximumFileSize" value="1000" />

      <param name="RollingStyle" value="Size" />

      <param name="StaticLogFileName" value="true" />

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

        <param name="ConversionPattern" value="%d [%t] %-5p %-45c [%x] - %m%n" />

      </layout>

    </appender>

    <!-- FileAppender appends to a log and it is manually managed or size -->

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

      <param name="File" value="LogHelloWorld.log" />     

      <!-- Example using environment variables in params -->

      <!-- <param name="File" value="${TMP}\\ApplicationKit.log" /> -->

      <param name="AppendToFile" value="true" />

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

        <param name="ConversionPattern" value="%d [%t] %-5p %c [%x] - %m%n" />

      </layout>

    </appender>

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

    <root>

      <level value="INFO" />

      <appender-ref ref="ConsoleAppender" />

    </root>

    <!-- ApplicationKit category - the presentation UI -->

    <logger name="WebForm1">

      <level value="INFO" />

      <appender-ref ref="FileAppender" />

    </logger>

 </log4net>

</configuration>

 

注意Logger節(jié)點(diǎn)的NAME屬性設(shè)的是WebForm1,這里指的是類名。要給每一個(gè)需要添加LOG的類都添加一個(gè)這樣的節(jié)點(diǎn)。想起了OSWORKFLOW工作流了,靈活與方便實(shí)用往往不可兼得。這里的級別是INFO,也就是說,INFO以下的不會被記錄。

Running the Sample Application

 

Step 5: 添加一個(gè) Log 類

首先是添加引用

using log4net;using log4net.Config; //然后是實(shí)例化如果認(rèn)真研究了配置文件,那么這個(gè)聲明方式就很好理解了:private static readonly ILog log = LogManager.GetLogger("WebForm1");


Step 6: 使用 Log對象

到了現(xiàn)在,所有的配置工作都已經(jīng)完成了,接下來的工作就是測試一下,把他和應(yīng)用層連起來。隨便加一個(gè)按鈕在響應(yīng)事件Button1_Click event handler.中添加


log.Info("Hello World, I am a logger");


Step 7: Run the Application

現(xiàn)在可以運(yùn)行了,應(yīng)該是個(gè)這樣子的:

這樣每次點(diǎn)擊按鈕,在日至文件中就會出現(xiàn)

2006-02-13 10:12:30,671 [1228] INFO WebForm1 [] - Hello World, I am a logger這樣一條記錄。


總結(jié):

簡單易用,過一陣再研究SQL日志吧,DB才素王道,呵呵。

更多信息參見http://logging.apache.org/log4net

本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊舉報(bào)。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
ASP.NET使用Memcached高緩存實(shí)例(初級教程) - VC/MFC/C++/ja...
CSDN技術(shù)中心 Log4Net使用指南
Log4Net五步走
C# 利用log4net 把日志寫入到數(shù)據(jù)庫
.NET后端知識匯總
文件并發(fā)(日志處理)
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服