【问题标题】:How to write log details to a file using .NET Core 6如何使用 .NET Core 6 将日志详细信息写入文件
【发布时间】:2023-01-09 14:59:18
【问题描述】:

我只想知道,如何使用 .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();

【问题讨论】:

  • documentation 说明了完成此操作必须做的事情。询问之前请务必检查文档!通读它,选择一种方法,尝试一下。如果它不起作用,您可以告诉我们您尝试了什么,并清楚地解释它为什么不起作用。

标签: c# asp.net-core-webapi asp.net-core-6.0


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

您可以在 catch 块中记录您需要的任何内容,例如步骤、信息和异常。信息记录示例:

_logger.LogInformation($"API started at:{DateTime.Now}"); 

catch 块中的异常记录示例:

_logger.LogError(ex, $"{ex.Message} - {ex.InnerException?.Message}");

【讨论】:

  • 按照你说的我用什么代码登录文件,你能在配置后解释一下吗?前任。 log.warning() / log.error()
  • 您可以在 catch 块中记录您需要的任何内容,例如步骤、信息和异常。信息记录示例:_logger.LogInformation($"API started at:{DateTime.Now}"); catch块异常记录示例:_logger.LogError(ex, $"{ex.Message} - {ex.InnerException?.Message}");
【解决方案2】:

我认为使用默认日志记录选项是不可能的。 但是有了图书馆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();

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-05-21
    • 2012-03-24
    • 1970-01-01
    • 2016-01-02
    • 2021-06-01
    相关资源
    最近更新 更多