.NET Core项目中 Serilog日志文件配置

一、安装需要的NuGet包

dotnet add package Serilog.AspNetCore

二、在 Program.cs 中配置 Serilog

cs 复制代码
//日志创建规则
Log.Logger = new LoggerConfiguration()
    .WriteTo.Console()
    .WriteTo.File("Logs/log-.txt", rollingInterval: RollingInterval.Day)
    .CreateLogger();


var builder = WebApplication.CreateBuilder(args);

builder.Host.UseSerilog();

//从配置文件中的读取 Serilog 配置
Log.Logger = new LoggerConfiguration()
    .ReadFrom.Configuration(builder.Configuration)
    .CreateLogger();


var app = builder.Build();

// 其他中间件和配置
app.Run();

三、在 appsettings.json 中添加 Serilog 配置

javascript 复制代码
"Serilog": {
  "MinimumLevel": "Information",
  "WriteTo": [
    { "Name": "Console" },
    {
      "Name": "File",
      "Args": {
        "path": "Logs/log-.txt",
        "rollingInterval": "Day"
      }
    }
  ]
},

四、Serilog的使用

4.1 在你的控制器或服务中注入 ILogger<T>

cs 复制代码
/// <summary>
/// Mes系统Api对接
/// </summary>
[Route("api/[controller]")]
[ApiController]
public class MesController : Controller
{
    private readonly ILogger<MesController> _logger;
    private readonly IMesService _mesService;

    public MesController(ILogger<MesController> logger,IMesService mesService)
    {
        _logger = logger;
        _mesService = mesService;
    }

    /// <summary>
    /// 订单包装数据返回
    /// </summary>
    /// <param name="model">WMS的数据结构</param>
    /// <returns></returns>
    [HttpPost("PostBackOrderPack")]
    public async Task<MessageResponse<string>> PostBackOrderPack(List<OrderPackDto> model)
    {
        try
        {
            var result = await _mesService.EditOrderPackDetailList(model);
            _logger.LogInformation("订单包装数据返回:" + result);
            return new MessageResponse<string>
            {
                Status = 200,
                Message = "获取成功",
                Success = true,
                Response = result
            };
        }
        catch (Exception ex)
        {
            _logger.LogWarning("订单包装数据返回异常:"+model);
            return new MessageResponse<string>
            {
                Status = 500,
                Message = $"接口异常:{ex}",
                Success = false,
            };
        }
    }
}

4.2 使用 Serilog 的 Log 静态类

cs 复制代码
//引用Serilog库
using Serilog;

//具体方法中使用
Log.Information("这是一个信息日志");
Log.Error("这是一个错误日志");

五、使用效果

在项目文件夹下会生成一个Logs文件夹,里面会存储对应的log文件

相关推荐
van久8 小时前
.Net Core 学习: Razor Pages -- EF Core简介
学习·.netcore
烛阴10 小时前
C#异常概念与try-catch入门
前端·c#
yue00812 小时前
C# Environment类的介绍
开发语言·c#·environment
c#上位机14 小时前
halcon图像去噪—高斯滤波
c#·上位机·halcon·机器视觉
van久14 小时前
.Net Core 学习:Razor Pages -- 依赖注入
学习·.netcore
神奇的板烧14 小时前
Java泛型不变性引发的类型转换问题及解决方案
java·c#
Aevget15 小时前
界面控件开发包DevExpress v25.1.7更新上线——修复一些小bug
c#·wpf·winform·devexpress·ui开发·用户界面
Q1808095116 小时前
手撕BP与CNN:不依赖外源库,探寻神经网络原理
c#
van久17 小时前
.Net Core 学习:Razor Pages -- EF Core工作原理
数据库·学习·.netcore
c#上位机17 小时前
halcon图像分割之动态阈值分割
图像处理·人工智能·计算机视觉·c#·halcon