Log4net使用

一、Log4net的使用步骤

1、引用log4net.dll
2、创建配置文件
3、关联配置文件
4、创建或获取日志对象
5、输出日志信息

二、关联配置文件

1、当创建了上面的配置文件后,需要把它和我们的应用联系起来。log4net默认关联的是应用程序的配置文件App.config(BS程序是Web.config),也可以使用程序集自定义属性(log4net.Config.XmlConifguratorAttribute)来进行设置。

2、XmlConfiguratorAttribute有3个属性:

1)ConfigFile: 配置文件的名字,文件路径相对于应用程序目录
(AppDomain.CurrentDomain.BaseDirectory)。ConfigFile属性不能和ConfigFileExtension属性一起使用。
2)ConfigFileExtension: 配置文件的扩展名,文件路径相对于应用程序的目录。ConfigFileExtension属性不能和ConfigFile属性一起使用。
3)Watch: 如果将Watch属性设置为true,就会监视配置文件。当配置文件发生变化的时候,就会重新加载。

如果ConfigFile和ConfigFileExtension都没有设置,则使用应用程序的配置文件App.config(Web.config)。

可以在项目的AssemblyInfo.cs文件里添加以下的语句:

//监视默认的配置文件,App.exe.config   
[assembly: log4net.Config.XmlConfigurator(Watch = true)]

//监视配置文件,App.exe.log4net。
[assembly: log4net.Config.XmlConfigurator(ConfigFileExtension = "log4net", Watch = true)]

//使用配置文件log4net.config,不监视改变。注意log4net.config文件的目录,BS程序在站点目录//下,CS则在应用程序启动目录下,如调试时在\bin\Debug下,一般将文件属性的文件输出目录调为//始终复制即可
[assembly: log4net. Config.XmlConfigurator(ConfigFile = "log4net.config")]

 //使用配置文件log4net.config,不监视改变
[assembly: log4net. Config.XmlConfigurator()]

也可以在Global.asax的Application_Start里或者是Program.cs中的Main方法中添加,注意这里一定是绝对路径,如下所示:

//这是在BS程序下,使用自定义的配置文件log4net.xml,使用Server.MapPath("~") + //@"\log4net.xml”来取得路径。 \log4net.xml为相对于站点的路径
// ConfigureAndWatch()相当于Configure(Watch = true)
log4net.Config.XmlConfigurator.ConfigureAndWatch(
new System.IO.FileInfo(Server.MapPath("~") + @"\log4net.xml"));

//这是在CS程序下,可以用以下方法获得:
string assemblyFilePath = Assembly.GetExecutingAssembly().Location;
string assemblyDirPath = Path.GetDirectoryName(assemblyFilePath);
string configFilePath = assemblyDirPath + " \\log4net.xml";
log4net.Config.XmlConfigurator.ConfigureAndWatch(new FileInfo(configFilePath));

//或直接使用绝对路径:
//使用自定义的配置文件,直接绝对路径为:c:/log4net.config
log4net.Config.XmlConfigurator.Configure(new System.IO.FileInfo(@"c:/log4net.config"));

三、创建或获取日志对象

日志对象会使用在配置文件里定义的属性。如果某个日志对象没有事先在配置文件里定义,那么框架会根据继承结构获取祖先节点的属性,最终的,会从根日志获取属性。如下所示:

Log4net.ILog log =Log4net.LogManager.GetLogger("MyLogger");

四、输出日志信息

可以使用ILog的几种方法输出日志信息。你也可以在调用某方法前先检查IsXXXEnabled布尔变量,再决定是否调用输出日志信息的函数,这样可以提高程序的性能。因为框架在调用如ILog.Debug(…)这样的函数时,也会先判断是否满足Level日志级别条件。

if (log.IsDebugEnabled) log.Debug("message");
if (log.IsInfoEnabled) log.Info("message);
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
log4net是一个功能强大的日志记录工具,它可以帮助开发人员在应用程序中实现灵活的日志记录功能。下面是一个简单的log4net使用教程: 1. 引入log4net库:首先,你需要从Apache log4net官方网站(https://logging.apache.org/log4net/)下载log4net库,并将它添加到你的项目中。 2. 配置log4net:在你的应用程序的配置文件(通常是App.config或Web.config)中添加log4net的配置节。以下是一个示例配置: ```xml <configuration> <configSections> <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" /> </configSections> <log4net> <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender"> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger - %message%newline" /> </layout> </appender> <root> <level value="DEBUG" /> <appender-ref ref="ConsoleAppender" /> </root> </log4net> </configuration> ``` 上面的配置定义了一个名为ConsoleAppender的日志输出器,它将日志消息输出到控制台。`<root>`元素指定了根日志记录器的日志级别和使用的输出器。 3. 初始化log4net:在应用程序启动时,通过调用`log4net.Config.XmlConfigurator.Configure()`方法来初始化log4net。例如,在应用程序的入口点中添加以下代码: ```csharp using log4net; namespace YourApplication { class Program { private static readonly ILog log = LogManager.GetLogger(typeof(Program)); static void Main(string[] args) { log4net.Config.XmlConfigurator.Configure(); log.Debug("Debug message"); log.Info("Info message"); log.Warn("Warning message"); log.Error("Error message"); log.Fatal("Fatal message"); } } } ``` 在上面的示例中,`GetLogger`方法用于获取一个log4net日志记录器,你需要将`typeof(Program)`替换为你所在的类的类型。 4. 记录日志:现在,你可以使用`log`对象来记录日志消息。log4net提供了不同的日志级别,包括DEBUG、INFO、WARN、ERROR和FATAL。你可以使用适当的日志级别来记录不同严重程度的消息。 以上是一个简单的log4net使用教程,希望对你有帮助!如果你有任何进一步的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值