查看: 479|回复: 0

[.NET开发] .net下log4net使用方法详解

发表于 2018-1-2 08:00:00

本文实例为大家分享了.net下log4net的使用方法,供大家参考,具体内容如下

这里以控制台应用程序为例

首先是要添加引用:

安装后可以看到项目中多了log4net的引用:

添加应用程序配置文件app.config,配置log4net

  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <configuration>
  3. <configSections>
  4. <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
  5. </configSections>
  6. <log4net>
  7. <!-- Define some output appenders -->
  8. <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
  9. <!--日志路径-->
  10. <file value="test.txt"/>
  11. <!--是否向文件中追加日志-->
  12. <appendToFile value="true"/>
  13. <!--日志保留天数-->
  14. <maxSizeRollBackups value="10"/>
  15. <!--每个文件的大小。只在混合方式与文件大小方式下使用。超出大小后在所有文件名后自动增加正整数重新命名,数字最大的最早写入。可用的单位:KB|MB|GB。不要使用小数,否则会一直写入当前日志-->
  16. <maximumFileSize value="1024KB"/>
  17. <!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])-->
  18. <rollingStyle value="Size"/>
  19. <!--否只写到一个文件中-->
  20. <staticLogFileName value="true"/>
  21. <layout type="log4net.Layout.PatternLayout">
  22. <!--记录时间:%date 线程ID:[%thread] 日志级别:%-5level 记录类:%logger 操作者ID:%property{Operator} 操作类型:%property{Action}%n 当前机器名:%property%n当前机器名及登录用户:%username %n 记录位置:%location%n 消息描述:%property{Message}%n 异常:%exception%n 消息:%message%newline%n%n-->
  23. <conversionPattern value="%date [%thread] %-5level %logger - %message%newline"/>
  24. </layout>
  25. </appender>
  26. <root>
  27. <level value="DEBUG"/>
  28. <appender-ref ref="RollingLogFileAppender"/>
  29. </root>
  30. </log4net>
  31. </configuration>
复制代码

在Program.cs中添加代码:

  1. static void Main(string[] args)
  2. {
  3. log4net.Config.XmlConfigurator.Configure();
  4. //创建日志记录组件实例
  5. ILog log = log4net.LogManager.GetLogger(typeof(Program));
  6. //记录错误日志
  7. log.Error("发生了错误:", new Exception("log4net的测试错误信息"));
  8. //记录致命的错误
  9. log.Fatal("发生了致命的错误:", new Exception("log4net测试致命信息"));
  10. //记录一般信息
  11. log.Info("log4net的一般信息");
  12. //记录调试信息
  13. log.Debug("log4net的调试信息");
  14. //记录警告信息
  15. log.Warn("log4net警告信息");
  16. Console.WriteLine("ok");
  17. Console.ReadKey();
  18. }
复制代码

运行程序

这里是控制台应用程序 ,如果是Web应用程序,可以在Global.asax.cs中Application_Start方法中调用log4net.Config.XmlConfigurator.Configure(); 在Global.asax.cs中定义一个变量,并在Application_Error中获取异常并记录:

  1. public class Global : System.Web.HttpApplication
  2. {
  3. private static ILog log = LogManager.GetLogger(typeof(Global));
  4. protected void Application_Start(object sender, EventArgs e)
  5. {
  6. log4net.Config.XmlConfigurator.Configure();
  7. }
  8. protected void Session_Start(object sender, EventArgs e)
  9. {
  10. }
  11. protected void Application_BeginRequest(object sender, EventArgs e)
  12. {
  13. }
  14. protected void Application_AuthenticateRequest(object sender, EventArgs e)
  15. {
  16. }
  17. protected void Application_Error(object sender, EventArgs e)
  18. {
  19. log.Error("发生了异常",Server.GetLastError());
  20. }
  21. protected void Session_End(object sender, EventArgs e)
  22. {
  23. }
  24. protected void Application_End(object sender, EventArgs e)
  25. {
  26. }
  27. }
复制代码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持程序员之家。



回复

使用道具 举报