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

相关推荐
八苦15 小时前
如何用c# 做 mcp/ChatGPT app
c#·mcp
人工智能AI技术16 小时前
DeskClaw Windows上线|C#开发AI桌面助手,轻量内核源码解析
人工智能·c#
似水明俊德16 小时前
04-C#.Net-委托和事件-面试题
java·开发语言·面试·c#·.net
程序员老乔19 小时前
Java 新纪元 — JDK 25 + Spring Boot 4 全栈实战(二):Valhalla落地,值类型如何让电商DTO内存占用暴跌
java·spring boot·c#
祝大家百事可乐20 小时前
嵌入式——02 数据结构
c++·c#·硬件工程
我是唐青枫20 小时前
深入理解 C#.NET TaskScheduler:为什么大量使用 Work-Stealing
c#·.net
唯情于酒1 天前
net core web api 使用log4net
c#·.net core
SunnyDays10111 天前
C# 实战:快速查找并高亮 Word 文档中的文字(普通查找 + 正则表达式)
开发语言·c#
人工智能AI技术1 天前
Qwen3.5-Plus登顶|C#集成通义千问,高并发服务实战优化
人工智能·c#
SunnyDays10111 天前
如何使用 C# 在 Word 文档中插入超链接 (含文本与图片链接)
开发语言·c#