.NET Core下使用Log4Net记录日志的方法步骤

 更新时间:2020-11-19 04:07:32   作者:佚名   我要评论(0)

Log4Net 相信大家都很熟悉了,算是比较主流和著名的日志组件了。
官网: logging.apache.org
开源地址: https://github.com/apache/logging-log4net
最佳实践
在项

Log4Net 相信大家都很熟悉了,算是比较主流和著名的日志组件了。

官网: logging.apache.org

开源地址: https://github.com/apache/logging-log4net

最佳实践

在项目中添加组件包

Install-Package log4net

添加 log4net.config 文件

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
 <configSections>
 <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
 </configSections>
 <log4net debug="false">

 <appender name="info" type="log4net.Appender.RollingFileAppender,log4net">
  <param name="File" value="log4net/info/" />
  <param name="AppendToFile" value="true" />
  <param name="MaxSizeRollBackups" value="-1"/>
  <param name="MaximumFileSize" value="5MB"/>
  <param name="RollingStyle" value="Composite" />
  <param name="DatePattern" value="yyyyMMdd\\HH&quot;.log&quot;" />
  <param name="StaticLogFileName" value="false" />
  <layout type="log4net.Layout.PatternLayout,log4net">
  <param name="ConversionPattern" value="%n
{
 &quot;system&quot;: &quot;Meowv.Blog&quot;,
 &quot;datetime&quot;: &quot;%d&quot;,
 &quot;description&quot;: &quot;%m&quot;,
 &quot;level&quot;: &quot;%p&quot;,
 &quot;info&quot;: &quot;%exception&quot;
}" />
  </layout>
  <filter type="log4net.Filter.LevelRangeFilter">
  <levelMin value="INFO" />
  <levelMax value="INFO" />
  </filter>
 </appender>

 <appender name="error" type="log4net.Appender.RollingFileAppender,log4net">
  <param name="File" value="log4net/error/" />
  <param name="AppendToFile" value="true" />
  <param name="MaxSizeRollBackups" value="-1"/>
  <param name="MaximumFileSize" value="5MB"/>
  <param name="RollingStyle" value="Composite" />
  <param name="DatePattern" value="yyyyMMdd\\HH&quot;.log&quot;" />
  <param name="StaticLogFileName" value="false" />
  <layout type="log4net.Layout.PatternLayout,log4net">
  <param name="ConversionPattern" value="%n
{
 &quot;system&quot;: &quot;Meowv.Blog&quot;,
 &quot;datetime&quot;: &quot;%d&quot;,
 &quot;description&quot;: &quot;%m&quot;,
 &quot;level&quot;: &quot;%p&quot;,
 &quot;info&quot;: &quot;%exception&quot;
}" />
  </layout>
  <filter type="log4net.Filter.LevelRangeFilter">
  <levelMin value="ERROR" />
  <levelMax value="ERROR" />
  </filter>
 </appender>

 <root>
  <level value="ALL"></level>
  <appender-ref ref="info"/>
  <appender-ref ref="error"/>
 </root>

 </log4net>

</configuration>

控制台项目

using log4net;
using log4net.Config;
using System;
using System.IO;
using System.Reflection;

namespace ConsoleAppDemo
{
 class Program
 {
  static void Main(string[] args)
  {
   var log4netRepository = LogManager.GetRepository(Assembly.GetEntryAssembly());
   XmlConfigurator.Configure(log4netRepository, new FileInfo("log4net.config"));

   ILog log = LogManager.GetLogger(log4netRepository.Name, "NETCorelog4net");

   log.Info("NETCorelog4net log");
   log.Info("test log");
   log.Error("error");
   log.Info("linezero");
   Console.ReadKey();
  }
 }
}

 

AspNetCore项目

新建一个静态类,写一个扩展方法 UseLog4Net() ,用于 log4net 初始化。

public static class Log4NetExtensions
{
 public static IHostBuilder UseLog4Net(this IHostBuilder hostBuilder)
 {
  var log4netRepository = LogManager.GetRepository(Assembly.GetEntryAssembly());
  XmlConfigurator.Configure(log4netRepository, new FileInfo("log4net.config"));

  return hostBuilder;
 }
}

扩展方法返回 IHostBuilder 对象,这样可以链式调用,美化代码,然后在 Program.cs 中使用扩展方法 UseLog4Net()

using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Hosting;

namespace WebAppDemo
{
 public class Program
 {
  public static void Main(string[] args)
  {
   CreateHostBuilder(args).Build().Run();
  }

  public static IHostBuilder CreateHostBuilder(string[] args) =>
   Host.CreateDefaultBuilder(args)
    .ConfigureWebHostDefaults(webBuilder =>
    {
     webBuilder.UseStartup<Startup>();
    }).UseLog4Net();
 }
}

配置完成,然后在任意地方写入日志即可。

using log4net;
using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using System.Linq;

namespace WebAppDemo.Controllers
{
 [ApiController]
 [Route("[controller]")]
 public class WeatherForecastController : ControllerBase
 {
  private static readonly string[] Summaries = new[]
  {
   "Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching"
  };

  private readonly ILog _log;

  public WeatherForecastController()
  {
   _log = LogManager.GetLogger(typeof(WeatherForecastController));
  }

  [HttpGet]
  public IEnumerable<WeatherForecast> Get()
  {
   _log.Info("Hello, this is a Weather api!");
   _log.Warn("Wran !!!");
   _log.Error("Controller Error");

   var rng = new Random();
   return Enumerable.Range(1, 5).Select(index => new WeatherForecast
   {
    Date = DateTime.Now.AddDays(index),
    TemperatureC = rng.Next(-20, 55),
    Summary = Summaries[rng.Next(Summaries.Length)]
   })
   .ToArray();
  }
 }
}

到此这篇关于.NET Core下使用Log4Net记录日志的方法步骤的文章就介绍到这了,更多相关.NET Core Log4Net内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • 详解.Net core2.0日志组件Log4net、Nlog简单性能测试
  • .net core整合log4net的解决方案

相关文章

  • .NET Core下使用Log4Net记录日志的方法步骤

    .NET Core下使用Log4Net记录日志的方法步骤

    Log4Net 相信大家都很熟悉了,算是比较主流和著名的日志组件了。 官网: logging.apache.org 开源地址: https://github.com/apache/logging-log4net 最佳实践 在项
    2020-11-19
  • .NET CORE3.1实现微信小程序发送订阅消息

    .NET CORE3.1实现微信小程序发送订阅消息

    一、appsettings.json定义小程序配置信息 "WX": {   "AppId": "wx88822730803edd44",   "AppSecret": "75b269042e8b5026e6ed14aa24ba9353",   "Templates":
    2020-11-19
  • .Net Core3.0 配置Configuration的实现

    .Net Core3.0 配置Configuration的实现

    准备 .NET core和.NET项目配置上有了很大的改变,支持的也更加丰富了比如命令行,环境变量,内存中.NET对象,设置文件等等。.NET项目我们常常把配置信息放到webConf
    2020-11-19
  • 在.NET中使用DiagnosticSource的方法

    在.NET中使用DiagnosticSource的方法

    前言 DiagnosticSource是一个非常有意思的且非常有用的API,对于这些API它们允许不同的库发送命名事件,并且它们也允许应用程序订阅这些事件并处理它们,它使我们
    2020-11-19
  • .NET Core3.0创建Worker Services的实现

    .NET Core3.0创建Worker Services的实现

    .NET CORE 3.0新增了Worker Services的新项目模板,可以编写长时间运行的后台服务,并且能轻松的部署成windows服务或linux守护程序。如果安装的vs2019是中文版本,
    2020-11-19
  • 详解ASP.NET Core Web Api之JWT刷新Token

    详解ASP.NET Core Web Api之JWT刷新Token

    前言 如题,本节我们进入JWT最后一节内容,JWT本质上就是从身份认证服务器获取访问令牌,继而对于用户后续可访问受保护资源,但是关键问题是:访问令牌的生命周期到
    2020-11-19
  • ASP.NET Core 实现基本认证的示例代码

    ASP.NET Core 实现基本认证的示例代码

    HTTP基本认证 在HTTP中,HTTP基本认证(Basic Authentication)是一种允许网页浏览器或其他客户端程序以(用户名:口令) 请求资源的身份验证方式,不要求cookie,sess
    2020-11-19
  • .NET Core3.0 日志 logging的实现

    .NET Core3.0 日志 logging的实现

    多年的经验,日志记录是软件开发的重要组成部分。没有日志记录机制的系统不是完善的系统。在开发阶段可以通过debug附件进程进行交互调试,可以检测到一些问题,但是
    2020-11-19
  • ASP.NetCore使用Swagger实战

    ASP.NetCore使用Swagger实战

    踩坑不背锅,.NET Core 试深浅 关于Swagger什么是swagger所带来的帮助 使用Swagger 关于Swagger 什么是swagger 使人和计算机在看不到源码或者看不到文档或者不能通过
    2020-11-19
  • 深入解读ASP.NET Core身份认证过程实现

    深入解读ASP.NET Core身份认证过程实现

    长话短说:上文我们讲了 ASP.NET Core 基于声明的访问控制到底是什么鬼? 今天我们乘胜追击:聊一聊ASP.NET Core 中的身份验证。 身份验证是确定用户身份的过程。
    2020-11-19

最新评论