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

相关推荐
z落落13 小时前
C#WinForm 窗体切换与窗体传值(登录跳转案例)+WinForm 窗体传值(从上往下传、从下往上传)
开发语言·windows·c#
ytttr87317 小时前
C# 定时数据库备份工具
开发语言·数据库·c#
雪豹阿伟18 小时前
21.Winfrom —— 定时器、日期选择器、进度条、表格、DataTable
c#·上位机·winfrom
z落落19 小时前
C#WinForm控件实战:Panel与单选框动态创建
开发语言·c#
qq_4221525721 小时前
Word 文件太大怎么压缩?2026 年文档瘦身方案对比
开发语言·c#·word
影寂ldy1 天前
C# 事件完整学习笔记(发布订阅 + 自定义事件 + 内置 EventHandler)
笔记·学习·c#
kyle~1 天前
DDS分布式实时系统---自省机制
开发语言·分布式·机器人·c#·接口·ros2
Java面试题总结1 天前
MarkItDown 再次登顶GitHub榜
开发语言·c#·github
xiaoshuaishuai81 天前
C# 定制化Markdown编辑器
开发语言·c#·编辑器
yugi9878381 天前
基于C#实现数字识别率的OCR方案
开发语言·c#·ocr