ASP.NET中使用Apachelog4net
来源:互联网 发布:鹦鹉螺雾化芯diy数据 编辑:程序博客网 时间:2024/06/10 09:27
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,期待正式版。
创建这个就不多说了,在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/
<script type="text/javascript"><!--google_ad_client = "pub-2947489232296736";/* 728x15, 创建于 08-4-23MSDN */google_ad_slot = "3624277373";google_ad_width = 728;google_ad_height = 15;//--></script><script type="text/javascript"src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
- ASP.NET中使用Apachelog4net
- ASP.NET中使用Caching
- asp.net 中使用sqlcommandbuilder
- asp.net中加密使用
- ASP.NET中使用基类库
- asp.net 中使用sqlcommandbuilder
- asp.net中使用线程
- asp.net 中使用计数器
- asp.net中cookie使用
- ASP.NET中使用Caching
- asp.net中使用sqlcommandbuilder
- ASP.NET 中使用 Cookie
- asp.net中DateTime使用
- asp.net中DateTime使用
- asp.net中DateTime使用
- ASP.NET中使用Caching
- asp.net中使用@ Register
- ASP.NET中使用jQGrid
- .net中错误日志的写入
- ASP.NET2.0的新特性:将一个ASP.NET网页发送到另一页之方法
- ASP.NET2.0中themes、Skins轻松实现网站换肤!
- .NET在SQLServer中的图片存取技术
- .net回收机制的使用
- ASP.NET中使用Apachelog4net
- 使用ASP.NETAtlasListView控件显示列表数据
- 如何让.Net控件在设计时InitializeComponent()中不生成相关代码
- .NET2.0泛型在实际开发中的一次小应用
- 在ASP.NETAtlas中创建自定义的Transformer
- 学习一下.netframework中有关安全的内容
- 对ASP.NET2.0下面的新控件的困惑
- 自定义ViewState的保存方式
- DataGrid的全选/取消全选控制(CheckBox)