.NET 6.0 WebAPI 应用log4net

.NET 6.0 WebAPI 应用log4net

第一步:引入依赖包

1. log4net
2. Microsoft.Extensions.Logging.Log4Net.AspNetCore

第二步:添加配置文件

在项目中添加“CfgConfig”文件夹,文件夹中添加“log4net.config”文件(这个文件可以创建在项目根目录下)。
<?xml version="1.0" encoding="utf-8"?>
<log4net>
	<!-- Define some output appenders -->
	<appender name="rollingAppender" type="log4net.Appender.RollingFileAppender">
		<!--日志文件路径-->
		<file value="Logs\" />
		<encoding value="utf-8"/>
		<!--文件名,按日期生成文件夹-->
		<datePattern value="/yyyy-MM-dd/'filename.log'" />

		<!--追加日志内容-->
		<appendToFile value="true" />

		<!--防止多线程时不能写Log,官方说线程非安全-->
		<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />

		<!--可以为:Once|Size|Date|Composite-->
		<!--Composite为Size和Date的组合-->
		<rollingStyle value="Composite" />

		<!--分割文件时在扩展名之前-->
		<preserveLogFileNameExtension value="true" />
		<!--当备份文件时,为文件名加的后缀-->
		<!--<datePattern value="yyyyMMdd.TXT" />-->

		<!--日志最大个数,都是最新的-->
		<!--rollingStyle节点为Size时,只能有value个日志-->
		<!--rollingStyle节点为Composite时,每天有value个日志-->
		<maxSizeRollBackups value="10" />

		<!--可用的单位:KB|MB|GB-->
		<maximumFileSize value="5MB" />

		<!--置为true,当前最新日志文件名永远为file节中的名字-->
		<staticLogFileName value="false" />

		<!--输出级别在INFO和ERROR之间的日志-->
		<filter type="log4net.Filter.LevelRangeFilter">
			<param name="LevelMin" value="INFO" />
			<param name="LevelMax" value="FATAL" />
		</filter>
		<layout type="log4net.Layout.PatternLayout">
			<conversionPattern value="%date{HH:mm:ss.fff} [%thread] %-5level %logger - %message%newline"/>
		</layout>
		<!--<layout type="log4net.Layout.PatternLayout">
			<conversionPattern value="[%d{HH:mm:ss}]%m%n"/>
		</layout>-->
	</appender>
	<root>
		<priority value="ALL"/>
		<level value="ALL"/>
		<appender-ref ref="rollingAppender" />
	</root>
</log4net>

第三步:将log4net加入程序集

在Program.cs文件中添加代码
using Microsoft.EntityFrameworkCore;
using MyToDoApi.Context;
using System.Runtime.CompilerServices;

var builder = WebApplication.CreateBuilder(args);

#region 将Log4Net加入Logging程序集(依赖注入)
//AddLog4Net函数中的参数是配置文件的路径
//如果这个文件创建在根目录下则不用输入参数
builder.Logging.AddLog4Net("CfgFile/log4net.config");
#endregion

// Add services to the container.
builder.Services.AddControllers();
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();

var app = builder.Build();

// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment())
{
    app.UseSwagger();
    app.UseSwaggerUI();
}

app.UseAuthorization();

app.MapControllers();

app.Run();

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值