.Net6 WebAPI使用log4net记录日志

文章目录

  • 一、log4net是什么?
  • 二、使用步骤
    • 1.添加配置文件
    • 2.Program使用配置文件
    • 3.封装log4net操作
      • 3.1新建一个类库,添加nuget包。
      • 3.2工具类
    • 4.使用方法


一、log4net是什么?

log4net是一个可以帮助程序员把日志信息输出到各种 不同目标的.net类库。它可以容易的加载到开发项目中,实现程序调试和运行的时候的日志信息输出,提供了比.net自己提供的debug类和trace 类的功能更多。log4net是从java下有卓越表现的log4j移植过来的。它是apache基金资助的项目的一部分。

二、使用步骤

1.添加配置文件

根目录下创建log4net.config配置文件
.Net6 WebAPI使用log4net记录日志_第1张图片

配置内容如下:


<configuration>
	
	<log4net>
		<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
			<layout type="log4net.Layout.PatternLayout" value="%date [%thread] %-5level %logger - %message%newline" />
		appender>

		<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
			<file value="logs/Error/" />
			<appendToFile value="true" />
			<rollingStyle value="Composite" />
			<staticLogFileName value="false" />
			<datePattern value="yyyyMMdd'.log'" />
			<maxSizeRollBackups value="10" />
			<maximumFileSize value="1MB" />
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%date [%thread] %-5level - %message%newline" />
			layout>
			<filter type="log4net.Filter.LevelRangeFilter">
				<levelMin value="ERROR" />
				
				<levelMax value="FATAL" />
			filter>
		appender>

		<appender name="WarnRollingFileAppender" type="log4net.Appender.RollingFileAppender">
			<file value="logs/Warn/" />
			<appendToFile value="true" />
			<rollingStyle value="Date"/>
			<datePattern value="yyyy-MM-dd'.log'"/>
			<maxSizeRollBackups value="100" />
			<staticLogFileName value="false" />
			<encoding value="utf-8" />
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%date [%thread] %-5level - %message%newline" />
			layout>
			<filter type="log4net.Filter.LevelRangeFilter">
				<levelMin value="WARN" />
				<levelMax value="WARN" />
			filter>
		appender>

		<appender name="InfoRollingFileAppender" type="log4net.Appender.RollingFileAppender">
			<file value="logs/Info/" />
			<appendToFile value="true" />
			<rollingStyle value="Date"/>
			<datePattern value="yyyy-MM-dd'.log'"/>
			<maxSizeRollBackups value="100" />
			<staticLogFileName value="false" />
			<encoding value="utf-8" />
			<layout type="log4net.Layout.PatternLayout">
				
				<conversionPattern value="%date [%thread] %-5level - %message%newline" />
			layout>
			<filter type="log4net.Filter.LevelRangeFilter">
				<levelMin value="TRACE " />
				<levelMax value="INFO" />
			filter>
		appender>

		
		<root>
			<level value="ALL" />
			<appender-ref ref="ConsoleAppender" />
			<appender-ref ref="FileAppender" />
			<appender-ref ref="RollingLogFileAppender" />
			<appender-ref ref="WarnRollingFileAppender" />
			<appender-ref ref="InfoRollingFileAppender" />
		root>

	log4net>
configuration>

2.Program使用配置文件

在Program.cs类中添加代码

暂可先不引用nuget包,使用下方封装类库中间接引用即可

ILoggerRepository repository = LogManager.CreateRepository("LogRepository");
XmlConfigurator.Configure(repository, new FileInfo("Config/log4net.config"));

3.封装log4net操作

3.1新建一个类库,添加nuget包。

.Net6 WebAPI使用log4net记录日志_第2张图片

3.2工具类

创建工具类
.Net6 WebAPI使用log4net记录日志_第3张图片
内容如下:
输出时添加了日志的调用类和调用方法名,如不需要可自行删除。

public class LogUtil
{
    private static readonly ILog log = LogManager.GetLogger("LogRepository", typeof(LogUtil));

    /// 
    /// 组织调用方法-日志信息
    /// 
    /// 
    private static string GetCallerNameAndMsg(string msg)
    {
        var callerMethod = new StackFrame(2, true)?.GetMethod();
        if (callerMethod == null)
        {
            return msg;
        }

        return $"{callerMethod.DeclaringType.FullName }.{callerMethod.Name}-{msg}";
    }

    /// 
    /// 日常日志
    /// 
    /// 
    /// 
    public static void Info(string msg)
    {
        if (log.IsInfoEnabled && !string.IsNullOrEmpty(msg))
        {
            log.Info(GetCallerNameAndMsg(msg));
        }
    }
    /// 
    /// 警告日志
    /// 
    /// 
    /// 
    public static void Warn(string msg)
    {
        if (log.IsWarnEnabled && !string.IsNullOrEmpty(msg))
        {
            log.Warn(GetCallerNameAndMsg(msg));
        }
    }

    /// 
    /// 错误日志
    /// 
    /// 
    /// 
    public static void Error(string msg)
    {
        if (log.IsErrorEnabled && !string.IsNullOrEmpty(msg))
        {
            log.Error(GetCallerNameAndMsg(msg));
        }
    }
}

4.使用方法

需要使用的项目引用Common类库,方法直接调用即可。

Common.Helper.LogUtil.Info("测试日志");

你可能感兴趣的:(WebApi,.net,webapi,log4net)