Log4net日志记录组件的使用步骤详解和下载
第一步
添加并应用Log4.dll。然后在Web.config文件中添加狼蚁网站SEO优化的配置局
<configSections>
<section name="log4" type="log4.Config.Log4NetConfigurationSectionHandler, log4" />
</configSections>
第二步
新建Log4Net.config的配置文件,并在其中添加狼蚁网站SEO优化的配置信息
<?xml version="1.0" encoding="UTF-8"?>
<log4 debug="false">
<!--按日期分割日志文件 一天一个-->
<appender name="LogFileAppenderByDate" type="log4.Appender.RollingFileAppender" >
<!--是否续写-->
<param name="AppendToFile" value=http://.blogs./huanghai223/archive/2012/02/21/"true" />
<!--最小锁定模型以允许多个进程可以写入同一个文件-->
<param name="LockingModel" value=http://.blogs./huanghai223/archive/2012/02/21/"log4.Appender.FileAppender.MinimalLock" />
<param name="StaticLogFileName" value=http://.blogs./huanghai223/archive/2012/02/21/"true" />
<!--保存路径-->
<param name="File" value=http://.blogs./huanghai223/archive/2012/02/21/"d:\Log\\" />
<param name="DatePattern" value=http://.blogs./huanghai223/archive/2012/02/21/"yyyy-MM-dd.LOG" />
<param name="StaticLogFileName" value=http://.blogs./huanghai223/archive/2012/02/21/"false" />
<param name="RollingStyle" value=http://.blogs./huanghai223/archive/2012/02/21/"Date" />
<layout type="log4.Layout.PatternLayout">
<param name="ConversionPattern" value=http://.blogs./huanghai223/archive/2012/02/21/"时间:%d %n级别:%level %n类名:%c%n文件:%F 第%L行%n日志内容:%m%n-----------------------------------------%n%n" />
</layout>
</appender>
<!--按日志容量分割日志文件 10KB一个-->
<appender name="LogFileAppenderBySize" type="log4.Appender.RollingFileAppender" >
<!--是否续写-->
<param name="AppendToFile" value=http://.blogs./huanghai223/archive/2012/02/21/"true" />
<!--最小锁定模型以允许多个进程可以写入同一个文件-->
<param name="LockingModel" value=http://.blogs./huanghai223/archive/2012/02/21/"log4.Appender.FileAppender.MinimalLock" />
<param name="StaticLogFileName" value=http://.blogs./huanghai223/archive/2012/02/21/"true" />
<!--按照文件的大小进行变换日志文件-->
<param name="RollingStyle" value=http://.blogs./huanghai223/archive/2012/02/21/"Size" />
<param name="File" value=http://.blogs./huanghai223/archive/2012/02/21/"log.txt" />
<!--单个文件最大数量 好像只有在 按Size分割时有效-->
<param name="MaximumFileSize" value=http://.blogs./huanghai223/archive/2012/02/21/"200KB"/>
<!--保留的log文件数量 超过此数量后 自动删除之前的 好像只有在 按Size分割时有效-->
<param name="MaxSizeRollBackups" value=http://.blogs./huanghai223/archive/2012/02/21/"2" />
<param name="StaticLogFileName" value=http://.blogs./huanghai223/archive/2012/02/21/"false" />
<layout type="log4.Layout.PatternLayout">
<param name="ConversionPattern" value=http://.blogs./huanghai223/archive/2012/02/21/"发生时间:%d %n事件级别:%level %n相关类名:%c%n程序文件:%F 第%L行%n日志内容:%m%n-----------------------------------------%n%n" />
</layout>
</appender>
<!--记录日志到数据库-->
<appender name="AdoNetAppender" type="log4.Appender.AdoNetAppender">
<bufferSize value=http://.blogs./huanghai223/archive/2012/02/21/"1" />
<!--缓冲大小-->
<connectionType value=http://.blogs./huanghai223/archive/2012/02/21/"System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<connectionString value=http://.blogs./huanghai223/archive/2012/02/21/"Data Source=.\SQLEXPRESS;Initial Catalog=CVDS;User ID=sa;Password=sasa" />
<mandText value=http://.blogs./huanghai223/archive/2012/02/21/"INSERT INTO Log([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" />
<parameter>
<parameterName value=http://.blogs./huanghai223/archive/2012/02/21/"@log_date" />
<dbType value=http://.blogs./huanghai223/archive/2012/02/21/"DateTime" />
<layout type="log4.Layout.RawTimeStampLayout" />
</parameter>
<parameter>
<parameterName value=http://.blogs./huanghai223/archive/2012/02/21/"@thread" />
<dbType value=http://.blogs./huanghai223/archive/2012/02/21/"String" />
<size value=http://.blogs./huanghai223/archive/2012/02/21/"255" />
<layout type="log4.Layout.PatternLayout">
<conversionPattern value=http://.blogs./huanghai223/archive/2012/02/21/"%thread" />
</layout>
</parameter>
<parameter>
<parameterName value=http://.blogs./huanghai223/archive/2012/02/21/"@log_level" />
<dbType value=http://.blogs./huanghai223/archive/2012/02/21/"String" />
<size value=http://.blogs./huanghai223/archive/2012/02/21/"50" />
<layout type="log4.Layout.PatternLayout">
<conversionPattern value=http://.blogs./huanghai223/archive/2012/02/21/"%level" />
</layout>
</parameter>
<parameter>
<parameterName value=http://.blogs./huanghai223/archive/2012/02/21/"@logger" />
<dbType value=http://.blogs./huanghai223/archive/2012/02/21/"String" />
<size value=http://.blogs./huanghai223/archive/2012/02/21/"255" />
<layout type="log4.Layout.PatternLayout">
<conversionPattern value=http://.blogs./huanghai223/archive/2012/02/21/"%logger" />
</layout>
</parameter>
<parameter>
<parameterName value=http://.blogs./huanghai223/archive/2012/02/21/"@message" />
<dbType value=http://.blogs./huanghai223/archive/2012/02/21/"String" />
<size value=http://.blogs./huanghai223/archive/2012/02/21/"4000" />
<layout type="log4.Layout.PatternLayout">
<conversionPattern value=http://.blogs./huanghai223/archive/2012/02/21/"%message" />
</layout>
</parameter>
<parameter>
<parameterName value=http://.blogs./huanghai223/archive/2012/02/21/"@exception" />
<dbType value=http://.blogs./huanghai223/archive/2012/02/21/"String" />
<size value=http://.blogs./huanghai223/archive/2012/02/21/"2000" />
<layout type="log4.Layout.ExceptionLayout" />
</parameter>
</appender>
<root>
<level value=http://.blogs./huanghai223/archive/2012/02/21/"INFO" />
<!--启用按日期分割-->
<appender-ref ref="LogFileAppenderByDate" />
<!--启用按容量分割-->
<!--<appender-ref ref="LogFileAppenderBySize" />-->
<!--启用保存到数据库-->
<!--<appender-ref ref="AdoNetAppender" />-->
</root>
</log4>
第三步
在Global.asax文件中的Application_Start事件中添加如下代码
protected void Application_Start(object sender, EventArgs e)
{
// Code that runs on application startup
log4.Config.XmlConfigurator.ConfigureAndWatch(new FileInfo(Server.MapPath("Log4Net.config")));
}
第四步调用LOG4 写日志
protected void Button2_Click(object sender, EventArgs e)
{
ILog logs = LogManager.GetLogger(typeof(TEST));
logs.Fatal("Excption:这里就是要提示的LOG信息");
}
也可以通过写一个LogHelper.cs类进行封装
using System;
using System.Collections.Generic;
using System.Web;
using log4;
namespace SBIT.Web.Class
{
/// <summary>
/// 日志辅助类
/// </summary>
public class LogHelper
{
private static ILog log;
private static LogHelper logHelper = null;
/// <summary>
/// 初始化
/// </summary>
/// <returns></returns>
public static ILog GetInstance()
{
logHelper = new LogHelper(null);
return log;
}
/// <summary>
/// 初始化
/// </summary>
/// <param name="configPath"></param>
/// <returns></returns>
public static ILog GetInstance(string configPath)
{
logHelper = new LogHelper(configPath);
return log;
}
/// <summary>
/// 构造函数
/// </summary>
/// <param name="configPath"></param>
private LogHelper(string configPath)
{
if (!string.IsNullOrEmpty(configPath))
{
log = log4.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
log4.Config.XmlConfigurator.Configure(new System.IO.FileInfo(configPath));
}
else
{
log = log4.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
}
}
}
}
通过封装类写日志的方法如下
private static readonly ILog logs = LogHelper.GetInstance(); //LogManager.GetLogger(typeof(TEST));
protected void Button2_Click(object sender, EventArgs e)
{
logs.Fatal("Excption:这里就是要提示的LOG信息");
}
Log4下载地址
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程