zoukankan      html  css  js  c++  java
  • .net下log4net的使用

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

    首先是要添加引用:

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

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

    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
      <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
      </configSections>
      <log4net>
        <!-- Define some output appenders -->
        <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
          <!--日志路径-->
          <file value="test.txt"/>
          <!--是否向文件中追加日志-->
          <appendToFile value="true"/>
          <!--日志保留天数-->
          <maxSizeRollBackups value="10"/>
          <!--每个文件的大小。只在混合方式与文件大小方式下使用。超出大小后在所有文件名后自动增加正整数重新命名,数字最大的最早写入。可用的单位:KB|MB|GB。不要使用小数,否则会一直写入当前日志-->
          <maximumFileSize value="1024KB"/>
          <!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])-->
          <rollingStyle value="Size"/>
          <!--否只写到一个文件中-->
          <staticLogFileName value="true"/>
          <layout type="log4net.Layout.PatternLayout">
            <!--记录时间:%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-->
            <conversionPattern value="%date [%thread] %-5level %logger - %message%newline"/>
          </layout>
        </appender>
        <root>
          <level value="DEBUG"/>
          <appender-ref ref="RollingLogFileAppender"/>
        </root>
      </log4net>
    </configuration>

    在Program.cs中添加代码:

    static void Main(string[] args)
    {
        log4net.Config.XmlConfigurator.Configure();
        //创建日志记录组件实例
        ILog log = log4net.LogManager.GetLogger(typeof(Program));
        //记录错误日志
        log.Error("发生了错误:", new Exception("log4net的测试错误信息"));
        //记录致命的错误
        log.Fatal("发生了致命的错误:", new Exception("log4net测试致命信息"));
        //记录一般信息
        log.Info("log4net的一般信息");
        //记录调试信息
        log.Debug("log4net的调试信息");
        //记录警告信息
        log.Warn("log4net警告信息");
        Console.WriteLine("ok");
        Console.ReadKey();
    }

    运行程序,

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

    public class Global : System.Web.HttpApplication
    {
        private static ILog log = LogManager.GetLogger(typeof(Global));
    
        protected void Application_Start(object sender, EventArgs e)
        {
            log4net.Config.XmlConfigurator.Configure();
        }
    
        protected void Session_Start(object sender, EventArgs e)
        {
    
        }
    
        protected void Application_BeginRequest(object sender, EventArgs e)
        {
    
        }
    
        protected void Application_AuthenticateRequest(object sender, EventArgs e)
        {
    
        }
    
        protected void Application_Error(object sender, EventArgs e)
        {
            log.Error("发生了异常",Server.GetLastError());
        }
    
        protected void Session_End(object sender, EventArgs e)
        {
    
        }
    
        protected void Application_End(object sender, EventArgs e)
        {
    
        }
    }
  • 相关阅读:
    android app记录执行日志 捕获奔溃异常 ,存储日志到文件
    对扩展openflow协议的一点思考
    Echarts柱状图
    python实现插入排序
    MyBatis -- 对表进行增删改查(基于注解的实现)
    pat解题报告【1082】
    [Swift]LeetCode974. 和可被 K 整除的子数组 | Subarray Sums Divisible by K
    [Swift]LeetCode976. 三角形的最大周长 | Largest Perimeter Triangle
    [Swift]LeetCode345. 反转字符串中的元音字母 | Reverse Vowels of a String
    [Swift]LeetCode343. 整数拆分 | Integer Break
  • 原文地址:https://www.cnblogs.com/godbell/p/7193202.html
Copyright © 2011-2022 走看看