ASP.NET WebApi项目框架搭建(四):日志管理之log4net

2021-03-09 07:28

阅读:415

标签:div   nuget   类型   doc   好处   rap   log文件   type   sse   

一、前言

在项目开发的过程中,日志是必不可少的一部分,可以帮我们定位异常,分析错误原因等功能,log4net是.Net下一个非常优秀的开源日志记录组件。log4net记录日志的功能非常强大。它可以将日志分不同的等级,以不同的格式,输出到不同的媒介。本文主要是介绍在前几篇已经创建好的项目里加上日志处理机制

二、安装并使用log4net

1.使用nuget安装log4net

技术图片

 

2.log4net的用法类似下面的代码:

        [Route("log4")]
        [HttpGet]
        public IHttpActionResult Log()
        {
            // 通过LogManager的静态方法GetLogger生成一个Ilog对象
            ILog log = LogManager.GetLogger(typeof(IndexController)); // 下面是日志处理
            log.Debug("测试debug", new Exception("debug异常"));
            log.Info("测试Info", new Exception("Info异常"));
            log.Warn("测试Warn", new Exception("Warn异常"));
            log.Error("测试Error", new Exception("Error异常"));
            log.Fatal("测试Fatal", new Exception("Fatal异常"));
            return Ok("已经写入日志");

        }

3.运行项目,浏览器调用请求

技术图片

三、通过autofac解耦Ilog对象

1.我们用autofac的Module方式去注册log4net组件,项目AutoFac目录下新建Module文件夹,并新建LoggingModule类

 public class LoggingModule : Autofac.Module
    {
        private static void InjectLoggerProperties(object instance)
        {
            var instanceType = instance.GetType();

            // Get all the injectable properties to set.
            // If you wanted to ensure the properties were only UNSET properties,
            // here‘s where you‘d do it.
            var properties = instanceType
              .GetProperties(BindingFlags.Public | BindingFlags.Instance)
              .Where(p => p.PropertyType == typeof(ILog) && p.CanWrite && p.GetIndexParameters().Length == 0);

            // Set the properties located.
            foreach (var propToSet in properties)
            {
                propToSet.SetValue(instance, LogManager.GetLogger(instanceType), null);
            }
        }

        private static void OnComponentPreparing(object sender, PreparingEventArgs e)
        {
            e.Parameters = e.Parameters.Union(
              new[]
              {
        new ResolvedParameter(
            (p, i) => p.ParameterType == typeof(ILog),
            (p, i) => LogManager.GetLogger(p.Member.DeclaringType)
        ),
              });
        }

        protected override void AttachToComponentRegistration(IComponentRegistry componentRegistry, IComponentRegistration registration)
        {
            registration.Preparing += OnComponentPreparing;

            // Handle properties.
            registration.Activated += (sender, e) => InjectLoggerProperties(e.Instance);
        }
    }

这段代码为autofac官网里提供的,参考地址:http://autofaccn.readthedocs.io/en/latest/examples/log4net.html?highlight=module

 2.ContainerBuilerCommon下注册module

 public static IContainer GetWebApiContainer()
        {
            var builder = new ContainerBuilder();
            // 注册webapi的所有控制器
            builder.RegisterApiControllers(Assembly.GetExecutingAssembly());
            // 注册一个用于测试的组件。
            builder.RegisterType();
            //注册日志组件
            builder.RegisterModule();
            return builder.Build();
        }

3.控制器通过构造函数注入Ilog

        private ILog _log;
        public IndexController(ILog log, Person person)
        {
            _person = person;
            _log = log;
        }

4.新建get请求

        [Route("autolog4")]
        [HttpGet]
        public IHttpActionResult AutoLog()
        {
            // 通过LogManager的静态方法GetLogger生成一个Ilog对象
            _log.Debug("测试debug", new Exception("debug异常"));
            _log.Info("测试Info", new Exception("Info异常"));
            _log.Warn("测试Warn", new Exception("Warn异常"));
            _log.Error("测试Error", new Exception("Error异常"));
            _log.Fatal("测试Fatal", new Exception("Fatal异常"));
            return Ok("已经写入日志");

        }

5.现在编译程序后用postman工具的get方法访问接口:http://localhost:xxx/api/autolog4,程序是运行正常的 。但现在日志即没有写入到某个文件、数据库或是发送到邮件里,也没有输出到控制台上。这就是log4net的设计的好处,在程序里你只管做日志的处理,如调用ILog的Debug()、Info()、Warn()、Error()、Fatal(),至于日志是由什么机制去处理(如写入文件,写入数据库等)是由另一个流程来控制,即log4net的配置文件。如果程序里没有log4net的配置文件,程序也能正常运行。

四、配置Log4net

1.新建Log4net.config,代码如下

"1.0" encoding="utf-8"?>
"log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
"true" targetFramework="4.5.2" /> "4.5.2" /> "ErrorAppender" type="log4net.Appender.RollingFileAppender"> "log/error/error_" /> "true"/> "Date"/> "yyyy-MM-dd‘.log‘"/> "false"/> "MaxSizeRollBackups" value="100"/> "50M" /> "log4net.Layout.PatternLayout"> "%n========== %n【日志级别】%-5level %n【记录时间】%date %n【执行时间】[%r]毫秒 %n【出错文件】%F %n【出错行号】%L %n【出错的类】%logger 属性[%property{NDC}] %n【错误描述】%message %n【错误详情】%newline"/> "log4net.Filter.LevelRangeFilter,log4net"> "ERROR" /> "FATAL" /> "DebugAppender" type="log4net.Appender.RollingFileAppender"> "log/debug/debug_" /> "true"/> "Date"/> "yyyy-MM-dd‘.log‘"/> "false"/> "MaxSizeRollBackups" value="100"/> "50M" /> "log4net.Layout.PatternLayout"> "%n========== %n【日志级别】%-2level %n【记录时间】%date %n【执行时间】[%r]毫秒 %n【debug文件】%F %n【debug行号】%L %n【debug类】%logger 属性[%property{NDC}] %n【debug描述】%message"/> "log4net.Filter.LevelRangeFilter,log4net"> "DEBUG" /> "WARN" /> "ALL" /> ref ref="DebugAppender" /> ref ref="ErrorAppender" />

2.properties下的AssemblyInfo.cs文件里添加以下代码:

[assembly: XmlConfigurator(Watch = true, ConfigFile = "Log4Net.config")]

3.运行程序,调用日志请求,log4net会在项目主目录下的log文件夹生成日志文件

技术图片

 

 技术图片

 

DEBUG日志:

 技术图片

ERROR日志:

技术图片

 

ASP.NET WebApi项目框架搭建(四):日志管理之log4net

标签:div   nuget   类型   doc   好处   rap   log文件   type   sse   

原文地址:https://www.cnblogs.com/huguodong/p/12754808.html


评论


亲,登录后才可以留言!