如何使用.NET Core 6将日志详细信息写入文件

6

我想知道如何在.NET 6中将日志详情保存到指定文件中。我使用Visual Studio 2022创建了一个新的ASP.NET Core 6 Web API项目。之前,我使用StartUp.cs类来配置日志,但是在VS 2022中,已经没有了StartUp类。

我应该如何在Program.cs类中编写代码?

var builder = WebApplication.CreateBuilder(args);
builder.Services.AddDbContext<StudentDbContext>(options =>
    options.UseSqlServer(builder.Configuration.GetConnectionString("StudentDbContext")
    ?? throw new InvalidOperationException("Connection string 'StudentDbContext' not found.")));

// Add services to the container.

builder.Services.AddControllers();
builder.Services.AddAutoMapper(AppDomain.CurrentDomain.GetAssemblies());

builder.Services.AddScoped<IStudentRepository, StudentService>();

// Log Details (Using this path I want to save my all log details)
var path = Directory.GetCurrentDirectory();

// 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.UseHttpsRedirection();
app.UseAuthorization();
app.MapControllers();

app.Run();

1
文档中详细说明了如何完成此操作。在提问之前,请务必查阅文档!仔细阅读文档,选择一种方法并尝试实现。如果没有成功,您可以告诉我们您尝试过的方法,并清楚地解释它为何不起作用。 - mason
文档说明ASP.NET Core不包含用于将日志写入文件的日志提供程序。考虑使用第三方日志提供程序从ASP.NET Core应用程序中将日志写入文件。 - Dush
2个回答

9

您可以使用“Serilog.Extensions.Logging.File”NuGet将日志记录到文件中:

  • 右键单击您的项目,选择“管理NuGet包”。在浏览选项卡中搜索“Serilog.Extensions.Logging.File”,然后安装它。
  • 在appsettings.json中添加以下片段
"Logging": {
    "LogLevel": {
      "Default": "Information",
      "Microsoft.AspNetCore": "Warning"
    },
    "LogFilePath": "Logs\\log-{Date}.txt"
  }
  • 在 Program.cs 类中,在 builder.Build() 之后添加以下代码段
    var loggerFactory = app.Services.GetService<ILoggerFactory>();
loggerFactory.AddFile(builder.Configuration["Logging:LogFilePath"].ToString());    
  • 构建并运行您的项目。您将在项目的根目录中找到Logs文件夹。

您可以在控制器或服务中记录任何需要的内容,只需在构造函数中注入ILogger接口,如下所示。

 private readonly ILogger<HomeController> _logger;
 public HomeController(ILogger<HomeController> logger)
        {
            _logger = logger;
        }

以下是记录任何事项的示例,例如您的流程步骤、信息、警告或捕获块中的异常。信息记录示例:

_logger.LogInformation("API started at:"+DateTime.Now); 

在 catch 块中记录异常的示例:

_logger.LogError(ex, ex.Message);

1
请问您可以在按照您所说的进行配置后解释一下,我可以使用哪些代码来记录文件登录信息吗?例如 log.warning() / log.error()。 - Gnana Akilan
1
请修复JSON。似乎与appSettings.json中的内容不符。 - Francis Ducharme
1
_logger 是从哪里来的? - Alex S.
不要在日志消息中使用字符串插值,利用内置的结构化日志记录,特别是使用旨在接受结构化消息的Serilog。 - drzaus
1
@AlexS. 只需在构造函数中注入ILogger接口即可。我已经更新了答案。 - Mohammad Kamel
显示剩余2条评论

1

我认为默认的日志记录选项无法实现此功能。但是使用Serilog库,您可以达到您想要的效果。

var builder = WebApplication.CreateBuilder(args);

Log.Logger = new LoggerConfiguration()
    .MinimumLevel.Debug()
    .WriteTo.File($"Logs/{Assembly.GetExecutingAssembly().GetName().Name}.log")
    .WriteTo.Console()
    .CreateLogger();
builder.Logging.ClearProviders();
builder.Logging.AddSerilog();

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接