网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > ASP.NET技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.保存图片流到数据库之后固定显示.
.ASP.NET ViewState 初探 (1).
.解决asp.net安装后无法访问oracl.
.使用.NET实现断点续传.
.在IIS与.net框架中配置中把扩展名.
.ASP.NET极限:页面导航 (翻译).
.ASP.NET 2.0 - Enter Key - Defa.
.介绍几个ASP.NET中容易忽略但却很.
.UNIX时间戳与.net日期类的转换 .
.ASP.NET如何存取SQL Server数据库.
.asp.net如何生成图片验证码(简单) .
.aspnet_wp.exe could not be sta.
.asp.net 2.0 权限树的控制.
.DataGrid的多行提交.
.虚拟主机上asp.net运行权限不足问.
.Asp.net给站点某目录增加Aspnet用.
.ASP.NET 2.0里轻松获取数据库连接.
.ASP.NET 2.0中的输出缓存.
.将dataset以xml形式发给客户端下.
.使用ASP.NET Atlas编写显示真实进.

ASP.NET中使用Apache log4net

发表日期:2006-4-11


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] &lt;%X{auth}&gt; - %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/

 

上一篇:如何让.Net控件在设计时InitializeComponent()中不生成相关代码 人气:6371
下一篇:.net回收机制的使用 人气:5803
浏览全部ASP.NET的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐