当前位置: 首页
编程语言
NET 4.7 如何使用 NLog 将日志记录到数据库

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

热心网友 时间: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。

同类文章
更多
Ubuntu系统下使用Go语言实现机器学习的实践指南

Ubuntu系统下使用Go语言实现机器学习的实践指南

在Ubuntu上使用Go进行机器学习需先安装环境并配置工作空间,通过goget获取golearn等库。编写代码遵循数据加载、模型训练、预测评估的流程后运行程序。Go在性能与并发方面有优势,但生态不如Python丰富,更适合特定工程场景或统一技术栈的团队探索。

时间:2026-05-07 13:59
Ubuntu系统下Go语言程序打包方法与核心要点

Ubuntu系统下Go语言程序打包方法与核心要点

在Ubuntu中打包Go应用需关注环境配置、交叉编译与优化。通过GoModules管理依赖,使用CGO_ENABLED=0生成静态二进制文件以实现跨平台兼容。利用UPX和链接器参数减小体积,采用Docker多阶段构建制作最小镜像。交付时建议包含平台信息并签名,注意解决动态库依赖和版本锁定等常见问题。

时间:2026-05-07 13:58
Android开发中高效管理多个CheckBox组件的实用技巧

Android开发中高效管理多个CheckBox组件的实用技巧

在Android应用开发过程中,高效管理多个功能相似的复选框(CheckBox)是提升开发效率的关键。无论是应用设置界面、多选列表,还是动态生成的选项列表,如果对每个CheckBox都进行单独引用和操作,代码会迅速变得冗长且难以维护。那么,是否存在更优雅的解决方案?答案是肯定的——通过数组或动态集合

时间:2026-05-07 13:58
面向对象编程中封装字段如何提升代码安全性与维护性

面向对象编程中封装字段如何提升代码安全性与维护性

将类的公共字段改为私有,并提供公共的获取和设置方法,是提升代码安全性与可控性的基础重构。此举能防止外部随意读写,避免状态失控,并便于后续加入校验、脱敏等控制逻辑,适用于核心业务或敏感字段。

时间:2026-05-07 13:58
Master-Worker架构解析如何实现并发任务的负载均衡与结果高效合并

Master-Worker架构解析如何实现并发任务的负载均衡与结果高效合并

Master-Worker架构的核心在于实现任务划分、动态负载均衡与可靠结果合并的协同:任务必须具备无依赖性与可聚合性,负载需依据节点实时能力进行动态分配,结果合并则需通过唯一ID、版本号及超时重试机制确保不丢失、保顺序、容故障。 构建一个高性能的Master-Worker并发架构,核心在于系统性地

时间:2026-05-07 13:58
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程