中国站长下载-为中国站长提供最好最全的建站资源! 首 页发布资源有事留言繁體中文
设为首页
加入收藏
联系我们
 
您当前的位置:中国站长下载 -> 文章中心 -> 网页编程 -> .NET编程 -> 文章内容  虚拟主机 域名注册 退出登录 用户管理
栏目导航
· ASP编程 · .NET编程
· PHP编程 · JSP编程
· CGI 专区
热门文章
· sndvol32 - sndvol3...
· [组图] FLASH:《大话李白》...
· 个人网站到底能赚多...
· [图文] Rundll.exe是病毒吗...
· [组图] Flash:制作MV
· 价值12万元的网站SE...
· 网站创业者,你需要...
· 一个成功的网站设计...
· [图文] FLASH:韩国导航条解...
· 中国网站的赚钱模式...
相关文章
· [图文] 用ASP.NET 2.0设计网...
· [图文] 用ASP.NET 2.0设计网...
· [图文] 用ASP.NET 2.0设计网...
· [图文] 用ASP.NET 2.0设计网...
· [图文] 用ASP.NET 2.0设计网...
· ASP.NET中WebForm组...
· ASP.NET中WebForm组...
· ASP.NET中WebForm组...
· ASP.NET中WebForm组...
· ASP.NET计数器
ASP.NET中使用Apache log4net
作者:不详  来源:不详  发布时间:2006-8-14 8:26:43  发布人:chinazhan

 减小字体 增大字体

     log4net是Apache log4j的.net版,是一套XML配置型的日志引擎,正好最近有个程序需要日志系统,为了整合方便,就决定研究一下。感谢郝伟推荐。
  
   log4net系统划分了7个日志等级,如设置为"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: 创建 ASP.NET Web 应用程序
  
   创建这个就不多说了,在log4net-1.2.0-beta8\bin\net如图。找到对应的dll,添加到引用里。有的版本没有编译好的dll,那就自己编一下吧,用.NET V1.0的那个版本转换成1.1或2.0的。我觉得这不是工作失误,是故意的。他们玩java玩惯了的人好多都是这样。
  
  Configuring the Sample Application
  
  
  
  Step 3: 添加Assembly信息
  
  打开AssemblyInfo.cs文件,添加:
  
  [assembly: log4net.Config.DOMConfigurator()]
  这句话的意思是log4net系统会自动寻找配置文件Web.config从而获得并加载其中的配置信息。如果想log4net随时监视配置文件以便重新加载的话就
  稍微麻烦点了要这样写:
  
  
  [assembly:log4net.Config.DOMConfigurator(ConfigFile="filename",ConfigFileExtension="log4net",Watch=true)]
  
  Step 4: 添加配置信息
  
  要编辑Web.config文件了,真是每次看见它都有惊喜啊。找到configuration标签,configSections要紧挨着写到它下面(一点都不替别人考虑,要在有一个也跟他一样霸道怎么办?那就单写个它的日志配置文件吧!我估计APACHE他们就是这么想的)。看看例子吧:
  
  
  <?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节点的NAME属性设的是WebForm1,这里指的是类名。要给每一个需要添加LOG的类都添加一个这样的节点。想起了OSWORKFLOW工作流了,灵活与方便实用往往不可兼得。这里的级别是INFO,也就是说,INFO以下的不会被记录。
  
  Running the Sample Application
  
  
  
  Step 5: 添加一个 Log 类
  
  首先是添加引用
  
  using log4net;using log4net.Config; //然后是实例化如果认真研究了配置文件,那么这个声明方式就很好理解了:private static readonly ILog log = LogManager.GetLogger("WebForm1");
  
  
  Step 6: 使用 Log对象
  
  到了现在,所有的配置工作都已经完成了,接下来的工作就是测试一下,把他和应用层连起来。随便加一个按钮在响应事件Button1_Click event handler.中添加
  
  
  log.Info("Hello World, I am a logger");
  
  
  Step 7: Run the Application
  
  现在可以运行了,应该是个这样子的:
  
  这样每次点击按钮,在日至文件中就会出现
  
  2006-02-13 10:12:30,671 [1228] INFO WebForm1 [] - Hello World, I am a logger这样一条记录。
  
  
  总结:
  
  简单易用,过一阵再研究SQL日志吧,DB才素王道,呵呵。
  
  更多信息参见http://logging.apache.org/log4net/
  
  
  
  
    做人要厚道,请注明转自chinazhan中国站长(www.ChinaZhan.com)。

 
[] [返回上一页] [打 印] [收 藏]
∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [更多评论...]
中国站长下载
中国站长下载

本页只接受PR>=4 IT类站点连接,申请连接,谢谢您们的支持!希望我们的下载站能够真正帮到中国的站长们!
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图
Copyright © 2005-2006 ChinaZhan.Net. All Rights Reserved .