当前位置: 首页 > article >正文

gitru:一个由 Rust 打造的零依赖 Git 提交信息校验工具雅

一、项目背景与核心价值1. 解决的核心痛点Navicat的数据库连接密码并非明文存储而是通过AES算法加密后写入.ncx格式的XML配置文件中。一旦用户忘记密码常规方式只能重新配置连接效率极低。本项目只作为学习研究使用不做其他使用。2. 项目核心价值跨平台运行基于Avalonia与.NET 8支持Windows、macOS、Linux全平台多场景解密支持配置文件批量解析、单条连接解密、手动输入密文解密三种模式易用性拉满现代化UI界面支持深色模式操作流程极简轻量高效无需复杂依赖基于.NET原生能力实现核心算法解密速度毫秒级。二、技术栈选型与考量NavicatPassword的技术栈选择围绕「跨平台、低耦合、高性能」三个核心目标具体选型如下技术领域 选型 选型考量前端UI框架 Avalonia UI 替代WPF的跨平台UI框架API与WPF高度兼容原生支持多平台、深色模式、响应式布局后端开发语言 C# (.NET 8) .NET 8跨平台能力强性能优异原生支持加密算法、XML解析等核心能力架构模式 MVVM (CommunityToolkit.Mvvm) 解耦UI与业务逻辑简化数据绑定、命令管理提升代码可维护性加密算法 AES-128-CBC 匹配Navicat官方的加密标准保证解密准确性数据存储 SQLite 轻量级嵌入式数据库用于保存用户的解密设置、历史记录等配置文件解析 .NET XmlDocument/XDocument 原生XML解析能力高效处理Navicat的.ncx配置文件三、项目架构设计MVVM项目严格遵循MVVM架构模式代码目录结构与职责划分清晰核心目录如下对应项目NavicatPassword/目录NavicatPassword/├── Views/ # 视图层UI界面Axaml文件仅负责展示无业务逻辑│ ├── MainView.axaml # 主界面解密操作核心页面├── ViewModels/ # 视图模型层连接View与Model处理UI交互逻辑│ ├── MainViewModel.cs # 主界面逻辑文件选择、批量解密、单条解密├── Services/ # 服务层核心业务逻辑封装│ ├── SystemService.cs # 密码解密核心服务├── Utils/ # 工具层解密方法└── App.axaml.cs # 应用入口全局配置各层核心职责View视图层仅通过Axaml定义UI结构通过数据绑定绑定ViewModel的属性和命令无任何业务代码ViewModel视图模型层通过ObservablePropertyCommunityToolkit.Mvvm特性实现属性通知通过ICommand处理按钮点击、文件选择等UI交互调用Service层完成核心逻辑Service服务层封装核心业务逻辑解密、文件解析是项目的「业务核心」ViewModel仅调用Service不直接处理业务Model模型层定义数据结构如数据库连接信息、应用配置等仅承载数据无业务逻辑。这种架构的优势在于UI与业务逻辑完全解耦后续无论是修改界面样式还是优化解密算法都无需改动其他层的代码可维护性和扩展性大幅提升。四、核心功能实现解析1. 密码解密核心算法AES-128-CBCNavicat的密码加密采用固定的Key和IV这是解密的关键。项目的核心解密代码如下且完全基于.NET原生System.Security.Cryptography实现using System.Security.Cryptography;using System.Text;namespace NavicatPassword.Services;public static class NavicatDecryptService{// Navicat固定的Key和IV核心private static readonly byte[] _key Encoding.UTF8.GetBytes(libcckeylibcckey);private static readonly byte[] _iv Encoding.UTF8.GetBytes(libcciv libcciv );////// 解密Navicat加密的密码字节数组//////加密后的字节数组///明文密码///解密失败时抛出异常public static string DecryptNavicatPassword(byte[] cipherBytes){if (cipherBytes null || cipherBytes.Length 0){throw new ArgumentException(加密字节数组不能为空, nameof(cipherBytes));}try{using Aes aes Aes.Create();// 匹配Navicat的加密模式CBC PKCS7填充aes.Mode CipherMode.CBC;aes.Padding PaddingMode.PKCS7;aes.Key _key;aes.IV _iv;// 创建解密器并执行解密ICryptoTransform decryptor aes.CreateDecryptor(aes.Key, aes.IV);byte[] plainBytes decryptor.TransformFinalBlock(cipherBytes, 0, cipherBytes.Length);// 转换为UTF8明文return Encoding.UTF8.GetString(plainBytes);}catch (Exception ex){throw new ArgumentException(解密失败可能是密文格式错误, ex);}}////// 重载解密Base64编码的密文字符串//////Base64密文/// 明文密码public static string DecryptNavicatPassword(string cipherBase64){byte[] cipherBytes Convert.FromBase64String(cipherBase64);return DecryptNavicatPassword(cipherBytes);}}关键细节说明固定Key/IVNavicat所有版本均使用libcckeylibcckeyKey和libcciv libccivIV这是解密的核心前提填充模式必须使用PKCS7而非PKCS5否则解密结果会出现乱码异常处理针对空值、格式错误等场景做了容错保证用户体验。2. .ncx配置文件解析Navicat的.ncx文件是XML格式核心是节点包含连接名称、地址、加密密码等信息。解析逻辑封装在NcxFileParserService中核心步骤如下using System.Xml.Linq;using NavicatPassword.Models;namespace NavicatPassword.Services;public class NcxFileParserService{////// 解析.ncx配置文件提取所有数据库连接信息//////配置文件路径/// 数据库连接列表public List ParseNcxFile(string filePath){if (!File.Exists(filePath)){throw new FileNotFoundException(配置文件不存在, filePath);}XDocument doc XDocument.Load(filePath);var connections new List();// 遍历所有Connection节点foreach (var connNode in doc.Descendants(Connection)){var connection new NavicatConnection{Name connNode.Attribute(Name)?.Value ?? string.Empty,Host connNode.Element(Host)?.Value ?? string.Empty,Port connNode.Element(Port)?.Value ?? string.Empty,Database connNode.Element(Database)?.Value ?? string.Empty,// 加密密码是Base64编码的字符串CipherPassword connNode.Element(Password)?.Value ?? string.Empty};// 自动解密可选if (!string.IsNullOrEmpty(connection.CipherPassword)){try{connection.PlainPassword NavicatDecryptService.DecryptNavicatPassword(connection.CipherPassword);}catch{connection.PlainPassword 解密失败;}}connections.Add(connection);}return connections;}}解析逻辑的核心是提取节点的属性和子节点值并自动调用解密方法生成明文密码最终封装为NavicatConnection模型返回给ViewModel由View展示。五、跨平台适配要点基于Avalonia和.NET 8项目的跨平台适配几乎「零成本」但仍有几个关键细节需要注意文件路径适配需要自己手动导出文件打开Navicat-文件-导出连接-导出密码(一定要勾选弹框底部导出密码否则解析不到密码修正路径.ncx)UI适配Avalonia的布局系统原生支持响应式通过Grid、StackPanel等布局控件保证在不同分辨率、不同系统下的UI一致性深色模式通过Avalonia的ThemeVariant实现无需单独开发。发布打包通过.NET Publish命令可一键打包不同平台的可执行文件# Windows (x64)dotnet publish -c Release -r win-x64 --self-contained true -o publish/win# macOS (x64)dotnet publish -c Release -r osx-x64 --self-contained true -o publish/macos# Linux (x64)dotnet publish -c Release -r linux-x64 --self-contained true -o publish/linux六、使用场景与落地效果1. 核心使用场景开发人员找回密码忘记Navicat连接密码快速解析配置文件找回运维批量管理批量解析服务器上的Navicat配置文件统一管理数据库连接密码测试环境核查验证测试环境数据库密码是否符合规范提升安全合规性已通过测试版本Navicat Premium Lite (Free) 17.3.6版本。附项目快速上手从源码构建# 克隆仓库git clone https://gitee.com/dingshuanglei/NavicatPassword.gitorgit clone https://github.com/dingshuanglei/NavicatPassword.git# 进入目录cd NavicatPassword# 构建项目dotnet build -c Release# 运行dotnet run --project NavicatPassword/NavicatPassword.csproj核心操作流程选择Navicat的.ncx配置文件自动解析所有连接批量解密/单条解密查看明文密码或手动输入密文一键解密。肪秸渍负

相关文章:

gitru:一个由 Rust 打造的零依赖 Git 提交信息校验工具雅

一、项目背景与核心价值 1. 解决的核心痛点 Navicat的数据库连接密码并非明文存储,而是通过AES算法加密后写入.ncx格式的XML配置文件中。一旦用户忘记密码,常规方式只能重新配置连接,效率极低。本项目只作为学习研究使用,不做其他…...

5分钟掌握MouseJiggler:告别系统休眠的智能鼠标模拟解决方案

5分钟掌握MouseJiggler:告别系统休眠的智能鼠标模拟解决方案 【免费下载链接】mousejiggler Mouse Jiggler is a very simple piece of software whose sole function is to "fake" mouse input to Windows, and jiggle the mouse pointer back and forth…...

HTML怎么搜索关键词_HTML search类型input特点【说明】

HTML原生search输入框语义明确、自带清空按钮、支持系统级搜索行为及专用软键盘&#xff1b;需用<form>包裹并监听submit/search事件&#xff0c;禁用默认行为&#xff0c;且清空操作仅触发search事件。HTML原生有啥特别的它和普通text输入框渲染几乎一样&#xff0c;但语…...

SQL视图能否存储计算结果_引入虚拟列与计算字段应用

SQL视图无法存储计算结果&#xff0c;每次查询都会实时执行底层SELECT语句中的所有计算&#xff1b;如需固化计算结果&#xff0c;应使用虚拟列&#xff08;MySQL/PostgreSQL支持&#xff09;或物化视图&#xff08;PostgreSQL需手动刷新&#xff0c;Oracle等支持自动刷新&…...

5分钟搭建通义千问3-VL-Reranker:多模态重排序Web UI教程

5分钟搭建通义千问3-VL-Reranker&#xff1a;多模态重排序Web UI教程 1. 什么是多模态重排序&#xff1f;它能帮你解决什么问题&#xff1f; 想象一下这个场景&#xff1a;你在一个电商平台搜索“带花园的白色小房子”&#xff0c;搜索结果里蹦出来一堆东西——有商品描述文字…...

Cogito 3B镜像免配置教程:预置中文Prompt Engineering最佳实践库

Cogito 3B镜像免配置教程&#xff1a;预置中文Prompt Engineering最佳实践库 1. 快速了解Cogito 3B模型 Cogito v1预览版是Deep Cogito推出的混合推理模型系列&#xff0c;这个3B版本在大多数标准基准测试中都表现出色&#xff0c;超越了同等规模下最优的开源模型。这意味着即…...

SpringCloud进阶--Seata与分布式事务庇

起因是我想在搞一些操作windows进程的事情时&#xff0c;老是需要右键以管理员身份运行&#xff0c;感觉很麻烦。就研究了一下怎么提权&#xff0c;顺手瞄了一眼Windows下用户态权限分配&#xff0c;然后也是感谢《深入解析Windows操作系统》这本书给我偷令牌的灵感吧&#xff…...

前端使用AI试水报告蒲

1 实用案例 1.1 表格样式生成 本示例用于生成包含富文本样式与单元格背景色的Word表格文档。 模板内容&#xff1a; 渲染代码&#xff1a; # python-docx-template/blob/master/tests/comments.py from docxtpl import DocxTemplate, RichText # data: python-docx-temp…...

别再数据线了!用FastAPI 分钟搭个局域网文件+剪贴板神器罕

为 HagiCode 添加 GitHub Pages 自动部署支持 本项目早期代号为 PCode&#xff0c;现已正式更名为 HagiCode。本文记录了如何为项目引入自动化静态站点部署能力&#xff0c;让内容发布像喝水一样简单。 背景/引言 在 HagiCode 的开发过程中&#xff0c;我们遇到了一个很现实的问…...

macos简单配置openclaw又

1 实用案例 1.1 表格样式生成 本示例用于生成包含富文本样式与单元格背景色的Word表格文档。 模板内容&#xff1a; 渲染代码&#xff1a; # python-docx-template/blob/master/tests/comments.py from docxtpl import DocxTemplate, RichText # data: python-docx-template/bl…...

c++ ffmpeg之提取视频数据保存到本地yuv文件(亲测好用)

#ifndef VIDEO_TO_YUV_H #define VIDEO_TO_YUV_H#include<QDebug> #include<QObject> #include<QThread> #include<QMutex> #include<QWaitCondition> #include<QImage>...

AI NLP核心技术指南

AI NLP核心技术指南...

AI神经网络基础概念技术指南

AI神经网络基础概念技术指南...

别再被照片骗了!从手机到单反,5分钟搞懂镜头畸变(附常见场景对比图)

别再被照片骗了&#xff01;从手机到单反&#xff0c;5分钟搞懂镜头畸变&#xff08;附常见场景对比图&#xff09; 每次拍完照片回看时&#xff0c;总觉得哪里不对劲——明明站得笔直的闺蜜在画面边缘变成了"香蕉人"&#xff0c;精心构图的城市天际线像被哈哈镜扭曲…...

3步打造纯净Windows 11:用Win11Debloat告别系统臃肿

3步打造纯净Windows 11&#xff1a;用Win11Debloat告别系统臃肿 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other changes to declutter and cust…...

为什么你的大模型上线后总出幻觉?:从血缘断链到推理失控的5层归因与实时修复指南

第一章&#xff1a;大模型工程化中的模型血缘追踪 2026奇点智能技术大会(https://ml-summit.org) 模型血缘追踪是保障大模型全生命周期可审计、可复现与可治理的核心能力。在持续训练、微调、量化、蒸馏与部署的多阶段工程实践中&#xff0c;同一基础模型可能衍生出数十个变体…...

专家 VS镜像视界:镜像视界算不算AI公司?

&#x1f3af; 标准反杀答案如果按传统分类&#xff0c;我们当然使用AI技术&#xff1b;但如果从系统本质来看—— 我们不属于“AI公司”&#xff0c;而属于“空间智能基础设施公司”。AI只是我们系统中的一个模块&#xff0c; 而不是系统的核心。&#x1f9e0; 进阶拆解① 承认…...

【最后72小时解锁】SITS2026联邦学习工作坊原始代码包+训练轨迹可视化Dashboard(含PyTorch/FedNLP/SecureAgg三框架适配版),错过再无官方授权分发

第一章&#xff1a;SITS2026演讲&#xff1a;大模型联邦学习应用 2026奇点智能技术大会(https://ml-summit.org) 在SITS2026主会场&#xff0c;来自MIT与华为诺亚方舟实验室的联合团队展示了基于LLaMA-3架构的大模型联邦学习新范式——FedLLM。该方案突破传统参数平均&#x…...

镜像视界空间智能体系统的核心原理是否涉及人工智能技术?

一句话结论涉及人工智能&#xff0c;但本质不是AI系统。我们的核心是空间计算系统&#xff0c;AI只是其中一个工具层。&#x1f9e0; 分层拆解1️⃣ 底层&#xff1a;不是AI ——是空间几何计算系统最核心的能力是&#xff1a;空间反演&#xff08;Pixel → World&#xff09;多…...

为什么要做 GeoPipeAgent底

指令替换 项目需求&#xff1a;将加法指令替换为减法 项目目录如下 /MyProject ├── CMakeLists.txt # CMake 配置文件 ├── build/ #构建目录 │ └── test.c #测试编译代码 └── mypass2.cpp # pass 项目代码 一&#xff0c;测试代码示例 test.c // test.c #includ…...

创业机会:AI Agent Harness Engineering 在垂直专业市场的 7 大爆点

创业机会:AI Agent Harness Engineering 在垂直专业市场的 7 大爆点 1. 引言:AI Agent 时代的到来 在人工智能技术快速发展的今天,我们正站在一个新时代的门槛上。从早期的规则引擎到如今的大语言模型(LLMs),AI技术已经取得了令人瞩目的进步。然而,真正的革命可能在于AI…...

网络连接故障 [2604] 终极排查指南:从浏览器设置到系统修复

1. 错误代码2604的根源解析 遇到浏览器弹出"无网络连接 请检查你的网络设置 然后重试 [2604]"的提示时&#xff0c;很多用户会下意识地反复刷新页面或重启路由器。但根据我处理这类问题的经验&#xff0c;90%的情况都与SSL/TLS协议配置有关。这个错误代码通常出现在W…...

深入解析ULN2003电机驱动器:从原理到实战应用

1. ULN2003电机驱动器基础解析 第一次接触ULN2003时&#xff0c;我完全被这个小小的芯片震撼到了——谁能想到这个比指甲盖还小的黑疙瘩&#xff0c;竟然能直接驱动继电器和步进电机&#xff1f;作为电子爱好者入门电机驱动的"启蒙老师"&#xff0c;ULN2003确实是个…...

GNSS差分码偏差(DCB)的实战应用与数据处理指南

1. GNSS差分码偏差&#xff08;DCB&#xff09;的核心概念解析 第一次接触DCB这个概念时&#xff0c;我也被各种专业术语绕得头晕。简单来说&#xff0c;你可以把DCB想象成GNSS信号在传输过程中产生的"指纹识别误差"。就像不同品牌的手机充电线给同一台设备充电时&am…...

ES6——编程风格

编程风格1、块级作用域1.1、Iet取代var1.2、全局常量和线程安全1.3、严格模式2、字符串3、解构赋值4、对象5、数组6、函数7、Map结构8、Class9、模块10、ESLint的使用1、块级作用域 1.1、Iet取代var ES6提出了两个新的声明变量的命令&#xff1a;let和const。其中&#xff0c…...

从源码到挂载:剖析NVIDIA Container Toolkit的GPU设备注入机制

1. 从零理解NVIDIA Container Toolkit的GPU挂载机制 第一次在容器里运行nvidia-smi命令时&#xff0c;那种"魔法般"的体验让我记忆犹新。明明宿主机上能正常使用的GPU设备&#xff0c;怎么在容器里就凭空出现了&#xff1f;这背后的秘密就藏在NVIDIA Container Toolk…...

SQL中JOIN类型选择的业务逻辑分析_根据业务需求选择连接

INNER JOIN 不能用于需保留主表所有记录的场景&#xff0c;如统计未下单用户&#xff1b;错误地在LEFT JOIN的WHERE中过滤右表字段会使其退化为INNER JOIN&#xff1b;RIGHT JOIN基本可被LEFT JOIN替代&#xff1b;FULL OUTER JOIN在MySQL中不支持&#xff0c;业务“并集”宜用…...

别只打补丁了!聊聊Oracle 11.2.0.4在Windows上维护的那些事儿:补丁管理、版本兼容与OPatch工具详解

Oracle 11.2.0.4 Windows环境下的补丁管理艺术&#xff1a;从基础操作到战略规划 在Oracle数据库运维领域&#xff0c;补丁管理往往被视为一项基础性工作&#xff0c;但实际上它远不止是简单的"下载-安装-重启"流程。特别是在Windows平台上运行的Oracle 11.2.0.4版本…...

CYBER-VISION零号协议入门指南:一键部署,开启智能助盲新篇章

CYBER-VISION零号协议入门指南&#xff1a;一键部署&#xff0c;开启智能助盲新篇章 1. 引言&#xff1a;当科技成为视障者的眼睛 想象一下&#xff0c;当你走在繁忙的街道上&#xff0c;眼前的世界突然变得模糊不清——路边的台阶、迎面而来的行人、突然出现的障碍物都成了潜…...

别再让扩展坞‘抢电’了!手把手教你用LDR6282 APP智能分配USB-C功率

别再让扩展坞“抢电”了&#xff01;LDR6282芯片智能功率分配全攻略 每次连接扩展坞时&#xff0c;笔记本电量不增反减&#xff1f;外接硬盘频繁断开&#xff1f;这些困扰专业用户的“功率焦虑”问题&#xff0c;根源在于传统扩展坞的固定功率分配机制。本文将深度解析基于LDR…...