VS2010环境下log4net日志配置(包括smtp发送邮件的配置),我是在winForm中配置的,那么webForm中,是在web.config中配置的,配置的内容都是一样的,只不过配置文件不一样。
要想使用log4net,需要到官网去下载log4net.dll文件,下载下来添加到应用当中,
配置日志文件,日志的配置可以参考官方的例子:http://logging.apache.org/log4net/release/config-examples.html
<?xml version="1.0" encoding="utf-8" ?> <configuration> <configSections> <section name="log4net" type="System.Configuration.IgnoreSectionHandler"/> <!-- <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/> --> </configSections> <appSettings> </appSettings> <log4net> <!--定义输出到文件中--> <appender name="LogFileAppender" type="log4net.Appender.FileAppender"> <!--定义文件存放位置--> <file value="D:/log4netfile.txt" /> <appendToFile value="true" /> <rollingStyle value="Date" /> <datePattern value="yyyyMMdd-HH:mm:ss" /> <layout type="log4net.Layout.PatternLayout"> <!--每条日志末尾的文字说明--> <footer value="by 周公" /> <!--输出格式--> <!--样例:2008-03-26 13:42:32,111 [10] INFO Log4NetDemo.MainClass [(null)] - info--> <conversionPattern value="记录时间:%date 线程ID:[%thread] 日志级别:%-5level 出错类:%logger property:[%property{NDC}] - 错误描述:%message%newline" /> </layout> </appender> <!--定义输出到控制台命令行中--> <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender"> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" /> </layout> </appender> <!--定义输出到windows事件中--> <appender name="EventLogAppender" type="log4net.Appender.EventLogAppender"> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" /> </layout> </appender> <!--定义输出到数据库中,这里举例输出到Access数据库中,数据库为C盘的log4net.mdb--> <appender name="AdoNetAppender_Access" type="log4net.Appender.AdoNetAppender"> <connectionString value="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:log4net.mdb" /> <commandText value="INSERT INTO LogDetails ([LogDate],[Thread],[Level],[Logger],[Message]) VALUES (@logDate, @thread, @logLevel, @logger,@message)" /> <!--定义各个参数--> <parameter> <parameterName value="@logDate" /> <dbType value="String" /> <size value="240" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date" /> </layout> </parameter> <parameter> <parameterName value="@thread" /> <dbType value="String" /> <size value="240" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%thread" /> </layout> </parameter> <parameter> <parameterName value="@logLevel" /> <dbType value="String" /> <size value="240" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%level" /> </layout> </parameter> <parameter> <parameterName value="@logger" /> <dbType value="String" /> <size value="240" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%logger" /> </layout> </parameter> <parameter> <parameterName value="@message" /> <dbType value="String" /> <size value="240" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%message" /> </layout> </parameter> </appender> <appender name="SmtpAppender" type="log4net.Appender.SmtpAppender"> <authentication value="Basic" /> <to value="目标邮箱地址,多邮箱用逗号分隔" /> <from value="发送邮箱" /> <username value="发送邮箱的登录账号" /> <password value="发送邮箱的密码" /> <subject value="邮件测试:日志,邮件主题" /> <smtpHost value="smtp.163.com(发送邮箱的smtp地址)," /> <!-- 也就是 发送邮件的时候, 顺便发送 异常日志的 前5个日志信息(包含异常的日志) 这样做的目的是 便于观察, 是什么原因,导致了 异常的发生. 这个值好像 默认是 512. --> <bufferSize value="512" /> <lossy value="true" /> <!-- 下面的定义, 就是 日志级别 大于 WARN 的, 才发邮件. --> <evaluator type="log4net.Core.LevelEvaluator"> <threshold value="ERROR"/> </evaluator> <!-- 下面是 定义邮件的格式 (好多换行啊) --> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%property{log4net:HostName} :: %level :: %message %newlineLogger: %logger%newlineThread: %thread%newlineDate: %date%newlineNDC: %property{NDC}%newline%newline" /> </layout> </appender> <!--定义日志的输出媒介,下面定义日志以四种方式输出。也可以下面的按照一种类型或其他类型输出。--> <root> <level value="ALL" /> <!--文件形式记录日志--> <appender-ref ref="LogFileAppender" /> <!--控制台控制显示日志--> <appender-ref ref="ConsoleAppender" /> <!--Windows事件日志--> <appender-ref ref="EventLogAppender" /> <!-- 如果不启用相应的日志记录,可以通过这种方式注释掉 <appender-ref ref="AdoNetAppender_Access" /> --> <!-- 这个是 电子邮件的 Log 配置 --> <appender-ref ref="SmtpAppender"/> </root> </log4net> </configuration>
在项目的AssemblyInfo.cs文件中设置,log4net的配置可以单独写到一个文件中(默认的配置是在App.config配置文件中的),若单独写到一个文件中,就需要使用下面的第二条语句指定配置文件的路径
[assembly: log4net.Config.XmlConfigurator(Watch = true)] //[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Log4net.config", ConfigFileExtension = "config", Watch = true)]
在窗体应用程序
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using System.Reflection; using log4net; //下面的这一条语句可以写在这里,也可以写到那个AssemblyInfo.cs文件中,但是只能出现在一处 //[assembly: log4net.Config.XmlConfigurator(Watch = true)] namespace Log_mail { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { ILog log = log4net.LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); log.Error("error", new Exception("发生了一个异常")); //记录严重错误 log.Fatal("fatal", new Exception("发生了一个致命错误")); //记录一般信息 log.Info("info"); //记录调试信息 log.Debug("debug"); //记录警告信息 log.Warn("warn"); Console.WriteLine("日志记录完毕。"); Console.Read(); } } }
相关推荐
《深入理解log4net配置及其Demo实践》 log4net是.NET平台上的一款强大且灵活的日志记录框架,广泛应用于各种项目中,提供了一种结构化、可扩展的日志记录方式。本文将深入探讨log4net的配置细节,并通过实际的Demo...
**log4net配置说明及相关文件** 在软件开发中,日志记录是不可或缺的一部分,它能够帮助开发者追踪程序运行状态,定位错误和异常。log4net是.NET Framework中一个广泛使用的日志记录工具,由Apache软件基金会开发。...
**log4net配置详解** log4net是一款广泛应用于.NET平台的日志记录框架,它提供了一套强大且灵活的机制,帮助开发者记录应用程序运行时的信息。本文将深入解析log4net的配置及其主要组件。 **一、log4net的组件结构...
此部分定义了log4net配置节的名称为"log4net",并指定了处理此类配置的类型。 ##### 2. 日志根节点配置 ```xml ``` 这里设置log4net的日志级别最低为ALL,即记录所有级别的日志。 ##### 3. 日志记录器...
**log4net配置实例下载** 在软件开发过程中,日志记录是至关重要的,它能帮助开发者追踪程序运行状态,定位错误源头。Log4net是一款强大的、灵活的日志记录框架,广泛应用于.NET平台,由Apache软件基金会开发。本...
**Log4net配置应用** Log4net是一款广泛应用于.NET Framework中的日志记录工具,由Apache软件基金会开发。它提供了一种灵活且强大的机制,用于控制应用程序的日志输出,包括错误日志、调试信息以及性能跟踪等。在VS...
**log4net配置和应用示例** 在软件开发过程中,日志记录是不可或缺的一部分,它帮助开发者追踪程序运行状态,定位错误和异常。log4net是.NET Framework下的一款强大、灵活的日志记录工具,它源自Java平台的log4j,...
"Log4net配置样题(Winform)"这个标题表明这是一个关于使用log4net在Windows Forms(Winform)应用程序中进行日志记录的实例教程或示例项目。Log4net是Apache软件基金会的一个开源项目,提供了一个灵活且强大的日志...
本实例将详细介绍如何在WinForm应用中配置和使用Log4Net。 首先,我们要理解Log4Net的基本概念。Log4Net提供了一个可扩展的框架,通过定义不同的Appenders(输出目标),Layouts(输出格式)以及Filters(过滤规则...
在代码中,首先需要初始化log4net配置,这通常在应用程序启动时完成。然后,可以通过获取Logger实例并调用其方法来记录日志,如`logger.Debug("这是一个调试信息")`。 ```csharp using log4net; using System; ...
**log4net配置详解** 在C#开发中,日志记录是不可或缺的一部分,它帮助开发者追踪程序运行状态、定位错误和异常,以及进行性能分析。log4net是Apache的一个开源项目,提供了一种灵活且可扩展的日志记录框架,广泛...
log4net配置文件
《log4net配置使用详解》 log4net是一款在.NET平台上广泛使用的日志记录组件,它源于Apache的log4j项目,为开发者提供了强大的日志管理功能。通过灵活的配置,log4net可以将日志信息按照不同级别、不同格式输出到...
### Log4Net配置详解 #### 一、Log4Net简介 Log4Net是Apache开源组织为.NET环境提供的一款日志记录工具,它基于Java的日志框架log4j开发而来,继承了log4j的强大功能与灵活性。Log4Net能够帮助开发者在.NET应用...
这个"C# log4net配置demo"是一个示例,演示了如何在C#应用中集成并配置log4net,以及如何利用textbox和listview展示日志信息。 首先,`log4net`的核心概念包括Appender、Layout、Logger和Hierarchy。Appender负责将...
为了在程序启动时初始化log4net配置,需要在相应入口点调用`log4net.Config.XmlConfigurator.Configure()`。对于控制台应用程序,这通常在`Program.cs`的`Main`方法中进行;对于Web应用程序,可以在`Global.asax.cs`...
**log4net配置和帮助类** `log4net` 是一个强大的日志记录框架,广泛应用于.NET应用程序中,提供灵活的日志记录配置和多种输出方式。这个压缩包包含的资源旨在帮助开发者理解和使用`log4net`进行日志管理。 1. **...
本篇文章将深入探讨如何利用log4net配置自动删除过期日志文件,以及与之相关的编程实践。 首先,我们要理解标题提到的"C# log4net自动删除多少天前的log文件"。log4net提供了一种机制,可以定时清理旧的日志文件,...