.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文件

相关推荐
huluang1 小时前
Word文档批注智能克隆系统的设计与实现
开发语言·c#·word
kylezhao20192 小时前
C#上位机开发数据持久化:excel报表导入导出
开发语言·c#·excel
wangnaisheng4 小时前
【C#】RocketMQ、Redis的使用
c#
阿蒙Amon4 小时前
C#每日面试题-接口和抽象类的区别
开发语言·c#
ejjdhdjdjdjdjjsl6 小时前
深入理解C#泛型:从方法到约束
c#
bugcome_com6 小时前
WPF 核心布局控件全解析:从 Grid 到 UniformGrid 的实战应用
c#·wpf
wangnaisheng7 小时前
Intel IPP 图像处理相关函数
c++·c#·图像
阿蒙Amon7 小时前
C#每日面试题-简述可空类型
microsoft·面试·c#
huluang7 小时前
高性能Word文档批注处理器的设计与实现
开发语言·c#·word
Lv11770088 小时前
Visual Studio中的try -- catch
ide·笔记·c#·visual studio