首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
NET 4.7 如何使用 NLog 将日志记录到数据库

NET 4.7 如何使用 NLog 将日志记录到数据库

热心网友
94
转载
2026-05-07

1. 首先安装必要的NuGet包

第一步,咱们得把项目里需要的“砖瓦”——也就是那几个关键的NuGet包——给准备好。具体是下面这几个:

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

  • NLog:日志记录的核心库。
  • NLog.Config (可选):如果你想让配置文件自动生成,可以加上这个。

当然,别忘了根据你用的数据库类型,安装对应的提供程序。这里以SQL Server为例:

Install-Package NLog
Install-Package NLog.Config
Install-Package System.Data.SqlClient

2. 配置NLog.config文件

包装好了,接下来就是“施工图纸”了。在项目中添加或修改NLog.config文件,它的核心作用,就是告诉NLog怎么把日志存到数据库里。

我们来看一个基础配置示例。你需要把YourConnectionStringHere替换成自己真实的数据库连接字符串:




  
    
  

  
    
    
      
      
      
      
    
  

  
    
  

如果你的应用对性能比较敏感,担心日志记录拖慢主流程,那异步记录就是个不错的选择。配置上只需要稍作调整:




  
    
  

   
    
    
      
        
        
        
        
      
    
  

  
    
  

3. 创建数据库表

光有配置还不行,数据库那头得准备好“仓库”来接收日志。确保你的数据库里有一张结构匹配的表,用来存放登录记录。下面是一个典型的表结构:

CREATE TABLE LoginLogs (
    ID UNIQUEIDENTIFIER PRIMARY KEY,
    LoginName NVARCHAR(100),
    Message NVARCHAR(MAX),
    CreateTime DATETIME
)

4. 在代码中使用NLog记录登录日志

有了配置和表结构,万事俱备,只欠代码。在业务逻辑里调用NLog记录日志就非常直观了。下面是一个封装好的登录服务类示例:

using NLog;

public class LoginService
{
    // 获取当前类的日志记录器实例
    private static readonly Logger Logger = LogManager.GetCurrentClassLogger();

    public void LogLoginAttempt(string loginName, string message, bool isSuccess)
    {
        // 创建日志事件信息,并设定级别和消息内容
        var logEvent = new LogEventInfo
        {
            Level = isSuccess ? LogLevel.Info : LogLevel.Warn,
            Message = message
        };

        // 将业务数据(如登录名)添加到日志事件的属性中,以便在配置的layout里使用
        logEvent.Properties["LoginName"] = loginName;

        // 执行记录
        Logger.Log(logEvent);
    }
}

5. 使用示例

最后,我们来个“实战演练”。如何在具体的登录成功或失败场景中调用上面的服务呢?看下面这两行代码就明白了:

var loginService = new LoginService();

// 成功登录时,记录一条INFO级别的日志
loginService.LogLoginAttempt("john.doe", "User logged in successfully", true);

// 登录失败时(如密码错误),记录一条WARN级别的日志
loginService.LogLoginAttempt("john.doe", "Invalid password", false);

这样一来,不同状态的登录行为就会被清晰地区分并持久化到数据库里,后续无论是排查问题还是做审计分析,都会方便得多。

来源:https://www.jb51.net/aspnet/343942j5f.htm
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

Bitget交易所2026年发展前景与市场排名深度解析
web3.0
Bitget交易所2026年发展前景与市场排名深度解析

2026年,Bitget在交易所排行榜上展现出强劲的竞争力。其表现主要体现在用户资产安全体系的持续加固、多元化产品矩阵的成熟与创新,以及在合规与全球化布局上的显著进展。平台通过优化现货与衍生品交易体验,并深化Web3生态建设,巩固了其在行业中的领先地位,获得了市场与用户的广泛认可。

热心网友
05.07
NET开发中HttpClient使用避坑指南与最佳实践详解
编程语言
NET开发中HttpClient使用避坑指南与最佳实践详解

HttpClient的7个常见陷阱与规避指南 在 NET 生态里进行项目开发,HttpClient 几乎是调用外部 API 绕不开的一个工具。它的上手门槛很低,用起来很顺手,但恰恰是这份“简单”,让不少开发者放松了警惕。如果不清楚它内部的运作机制,一不小心就可能掉进坑里,轻则请求失败,重则引发服务

热心网友
05.07
NETCore与Linux服务器时间同步问题的多种解决方案详解
编程语言
NETCore与Linux服务器时间同步问题的多种解决方案详解

如何解决 NET Core项目与Linux服务器之间的时间同步问题 导语 搞分布式系统的开发者,多少都踩过时间不同步的“坑”。这事说大不大,说小不小——日志对不上、订单乱取消、交易出岔子,追根溯源,往往是几台机器的时间“各走各的”。尤其是在 NET Core应用遇上Linux服务器的场景,时区、格式

热心网友
05.07
NET 4.7 如何使用 NLog 将日志记录到数据库
编程语言
NET 4.7 如何使用 NLog 将日志记录到数据库

1 首先安装必要的NuGet包 第一步,咱们得把项目里需要的“砖瓦”——也就是那几个关键的NuGet包——给准备好。具体是下面这几个: NLog:日志记录的核心库。 NLog Config (可选):如果你想让配置文件自动生成,可以加上这个。 当然,别忘了根据你用的数据库类型,安装对应的提供程序。

热心网友
05.07
NETCore消息队列RabbitMQ实现方法与代码示例
编程语言
NETCore消息队列RabbitMQ实现方法与代码示例

在 NET Core 中玩转 RabbitMQ:从零搭建可靠的消息队列 消息队列是现代应用解耦和异步通信的基石,而 RabbitMQ 无疑是这个领域的明星选手。它基于 AMQP 协议,为不同应用程序间的可靠消息传递提供了强大支持。今天,我们就来深入聊聊,如何在 NET Core 环境中,亲手搭建

热心网友
05.07