博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
log4net使用详解
阅读量:4701 次
发布时间:2019-06-09

本文共 3421 字,大约阅读时间需要 11 分钟。

说明:本程序演示如何利用log4net记录程序日志信息。log4net是一个功能著名的开源日志记录组件。利用log4net可以方便地将日志信息记录到文件、控制台、Windows事件日志和数据库(包括MS SQL Server, Access, Oracle9i,Oracle8i,DB2,SQLite)中。并且我们还可以记载控制要记载的日志级别,可以记载的日志类别包括:FATAL(致命错误)、ERROR(一般错误)、WARN(警告)、INFO(一般信息)、DEBUG(调试信息)。要想获取最新版本的log4net组件库,可以到官方网站下载。现在的最新版本是1.2.10。

下面的例子展示了如何利用log4net记录日志 。

首先从官方网站下载最近版本的log4net组件,现在的最新版本是1.2.10。在程序中我们只需要log4net.dll文件就行了,添加对log4net.dll的引用,就可以在程序中使用了。

接着我们配置相关的配置文件(WinForm对应的是*.exe.config,WebForm对应的是*.config),本实例中是控制台应用程序,配置如下(附各配置的说明):

程序文件:

using System;using System.Collections.Generic;using System.Text;using System.Windows.Forms;using System.Reflection;using log4net;//注意下面的语句一定要加上,指定log4net使用.config文件来读取配置信息//如果是WinForm(假定程序为MyDemo.exe,则需要一个MyDemo.exe.config文件)//如果是WebForm,则从web.config中读取相关信息[assembly: log4net.Config.XmlConfigurator(Watch = true)]namespace Log4NetDemo{    ///     /// 说明:本程序演示如何利用log4net记录程序日志信息。log4net是一个功能著名的开源日志记录组件。    /// 利用log4net可以方便地将日志信息记录到文件、控制台、Windows事件日志和数据库中(包括MS SQL Server, Access, Oracle9i,Oracle8i,DB2,SQLite)。    /// 下面的例子展示了如何利用log4net记录日志    /// 作者:周公    /// 时间:2008-3-26    /// 首发地址:http://blog.csdn.net/zhoufoxcn/archive/2008/03/26/2220533.aspx    ///     public class MainClass    {        public static void Main(string[] args)        {            //Application.Run(new MainForm());            //创建日志记录组件实例            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();        }    }}

运行结果:

控制台上的输出

日志文件内容

 

在这里需要特别说明一下,注意上面的代码中有这么一句:[assembly: log4net.Config.XmlConfigurator(Watch = true)](在需要使用log4net的类的namespace处),如果没有这句就会在调试时得到如下留言中所说的“程序调试起来时isDebugEnable"的情况,希望大家注意。参考详细:http://blog.csdn.net/zhoufoxcn/article/details/6029021

转载于:https://www.cnblogs.com/wolfocme110/p/4455337.html

你可能感兴趣的文章
Thread--CountDownLatch & CyclicBarrier
查看>>
Oracle数据库断电后不能打开的解决2
查看>>
20 个强大的 Sublime Text 插件
查看>>
TCP/UDP各位数据详解
查看>>
python3 实现多域名批量访问特定目录(一)
查看>>
OracleINSERT提示IGNORE_ROW_ON_DUPKEY_INDEX
查看>>
java积累
查看>>
perl学习之:字符串函数
查看>>
开发过程中编写的一些批处理
查看>>
vuex的安装
查看>>
A desmos graph supersampling test
查看>>
局域网的某个机器无法上网,的排错思路
查看>>
Flex外观设计
查看>>
ASP.NET MVC上传文件
查看>>
Python 编程语言要掌握的技能之一:使用数字与字符串的技巧
查看>>
DER编码简介
查看>>
centos7 samba安装
查看>>
160. Intersection of Two Linked Lists
查看>>
centOS学习part6:安装oracle 11g
查看>>
Socketserver
查看>>