在 Visual Studio 中,右键单击解决方案,选择“管理 NuGet 包”(Manage NuGet Packages),搜索并安装 NLog 和 NLog.Web 包。
在项目的根目录中创建一个名为 nlog.config 的 XML 文件,其内容如下:
该配置定义了一个名为“logfile”的文件目标,并将任何错误日志记录到该文件中。
在 Program.cs 文件中添加以下代码:
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Hosting;
using NLog.Web;
namespace MyApp
{
public class Program
{
public static void Main(string[] args)
{
CreateHostBuilder(args).Build().Run();
}
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseNLog(); // 添加 NLog 中间件
webBuilder.UseStartup();
});
}
}
该代码在 ASP.NET Core 的主机中添加了 NLog 中间件,以启用日志记录和异常捕获。
在项目中添加一个名为 ErrorFilterAttribute 的过滤器(Filter)类,并将其应用于整个应用程序。
using Microsoft.AspNetCore.Mvc.Filters;
using NLog;
namespace MyApp.Filters
{
public class ErrorFilterAttribute : ExceptionFilterAttribute
{
private static Logger logger = LogManager.GetCurrentClassLogger();
public override void OnException(Exception