ASP NET Core 2.2 MVC中的NLog数据库目标不起作用
创始人
2024-11-11 17:00:59
0

要在ASP.NET Core 2.2 MVC中使用NLog数据库目标,您需要执行以下步骤:

  1. 安装NLog.Web.AspNetCore程序包。您可以在NuGet包管理器控制台中执行以下命令来安装它:
Install-Package NLog.Web.AspNetCore
  1. 在您的项目的appsettings.json文件中,添加NLog配置。例如:
"NLog": {
  "autoReload": true,
  "throwConfigExceptions": true,
  "internalLogLevel": "Info",
  "internalLogFile": "logs/internal-nlog.txt",
  "extensions": {
    "NLog.Targets.Database": {
      "assembly": "NLog.Targets.Database"
    }
  },
  "targets": {
    "database": {
      "type": "Database",
      "dbProvider": "Microsoft.Data.SqlClient.SqlConnection, Microsoft.Data.SqlClient",
      "commandText": "INSERT INTO Log ([Message]) VALUES (@message);",
      "parameters": [
        {
          "name": "@message",
          "layout": "${message}"
        }
      ],
      "connectionString": "your connection string"
    }
  },
  "rules": [
    {
      "logger": "*",
      "minLevel": "Info",
      "writeTo": "database"
    }
  ]
}

在上面的配置中,我们定义了一个名为“database”的目标,它将日志消息插入到名为“Log”的表中。您需要根据您的数据库配置和表结构进行相应的更改。

  1. 在您的Startup.cs文件中,添加NLog配置。在ConfigureServices方法中,添加以下代码:
using NLog.Extensions.Logging;
using Microsoft.Extensions.Logging;

...

public void ConfigureServices(IServiceCollection services)
{
    services.AddLogging(loggingBuilder =>
    {
        loggingBuilder.ClearProviders();
        loggingBuilder.AddNLog();
    });

    // 其他配置
}
  1. 在您的Startup.cs文件中,添加NLog中间件。在Configure方法中,添加以下代码:
using NLog.Web;

...

public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
    app.UseNLog();

    // 其他配置
}
  1. 确保您的NLog配置文件(通常是NLog.config或NLog.xml)位于您的项目根目录下,并且已设置为“始终复制”。

  2. 在您的控制器或其他类中,使用ILogger接口进行日志记录。例如:

using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Logging;

namespace YourNamespace.Controllers
{
    public class HomeController : Controller
    {
        private readonly ILogger _logger;

        public HomeController(ILogger logger)
        {
            _logger = logger;
        }

        public IActionResult Index()
        {
            _logger.LogInformation("Hello, NLog!");

            return View();
        }
    }
}

通过执行以上步骤,您应该能够在ASP.NET Core 2.2 MVC应用程序中使用NLog数据库目标来记录日志。请记住,在使用数据库目标之前,您需要确保数据库连接字符串有效,并且目标表已创建。

希望这可以帮助到您!

相关内容

热门资讯

黑科技科技(wepoke智能a... 黑科技科技(wepoke智能ai)wepower使用说明书(wepOkE)素来是真的有挂(确实有挂)...
黑科技模拟器(wepoke智能... WePoker透视辅助工具核心要点解析‌,黑科技模拟器(wepoke智能ai)wepoke是机器发牌...
黑科技脚本(wepokeai代... 您好,这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中打牌都...
黑科技辅助挂(wepoke真的... 黑科技辅助挂(wepoke真的有挂)wepoke 软件(wEPOKE)固有真的有挂(有挂猫腻)-哔哩...
黑科技辅助挂(wepoke黑科... 黑科技辅助挂(wepoke黑科技)wepoke软件透明挂演示(wEpOke)一直真的有挂(真的有挂)...
黑科技app(wepoke真的... 此外,数据分析德州()辅助神器app还具备辅助透视行为开挂功能,通过对客户透明挂的深入研究,你可以了...
黑科技智能ai(wepoke辅... 黑科技智能ai(wepoke辅助插件)wepoke软件透明(WEPOke)先前是有挂(果真有挂)-哔...
黑科技模拟器(wepoke透明... 黑科技模拟器(wepoke透明黑科技)wepoke德州扑克用ai代打(WEPOKE)最初存在有挂(有...
黑科技插件(wepoke辅助插... 黑科技插件(wepoke辅助插件)wepoke软件透明(WEPOke)从来是真的有挂(有挂解惑)-哔...
黑科技美元局(wepoke智能... 黑科技美元局(wepoke智能ai)wepoke辅助真的假的(wepoKE)原先真的有挂(竟然有挂)...