San*_*hna 7 c# asp.net-core-webapi asp.net-core-6.0
我只是想知道,如何使用 .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();
Run Code Online (Sandbox Code Playgroud)
Moh*_*mel 12
您可以使用“Serilog.Extensions.Logging.File”NuGet 记录到文件:
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
},
"LogFilePath": "Logs\\log-{Date}.txt"
}
Run Code Online (Sandbox Code Playgroud)
var loggerFactory = app.Services.GetService<ILoggerFactory>();
loggerFactory.AddFile(builder.Configuration["Logging:LogFilePath"].ToString());
Run Code Online (Sandbox Code Playgroud)
您可以在控制器或服务中记录您需要的任何内容,只需在构造函数中注入 ILogger 接口,如下所示。
private readonly ILogger<HomeController> _logger;
public HomeController(ILogger<HomeController> logger)
{
_logger = logger;
}
Run Code Online (Sandbox Code Playgroud)
以下是记录任何内容的示例,例如流程步骤、信息、任何位置的警告或 catch 块中的异常。信息记录示例:
private readonly ILogger<HomeController> _logger;
public HomeController(ILogger<HomeController> logger)
{
_logger = logger;
}
Run Code Online (Sandbox Code Playgroud)
catch 块中异常记录的示例:
_logger.LogInformation("API started at:"+DateTime.Now);
Run Code Online (Sandbox Code Playgroud)
小智 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();
Run Code Online (Sandbox Code Playgroud)