当前位置: 首页 > 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配置文件中。一旦用户忘记密码,常规方式只能重新配置连接,效率极低。本项目只作为学习研究使用,不做其他…...

抖音内容获取革命:智能下载引擎如何打破平台壁垒

抖音内容获取革命:智能下载引擎如何打破平台壁垒 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback support. 抖…...

深度学习图像分割终极指南:U-Net与ResNet-50的完美融合

深度学习图像分割终极指南:U-Net与ResNet-50的完美融合 【免费下载链接】pytorch-unet-resnet-50-encoder 项目地址: https://gitcode.com/gh_mirrors/py/pytorch-unet-resnet-50-encoder 还在为复杂的图像分割任务发愁吗?今天我要为你介绍一个基…...

python polars

# 关于Polars,一个Python数据处理库的深度观察 最近在数据处理的项目中频繁接触到Polars,这个库在社区里的讨论热度逐渐升高。作为在数据领域工作多年的开发者,觉得有必要梳理一下对这个工具的理解,特别是它和传统工具的区别以及实…...

如何用OpCore-Simplify在30分钟内完成黑苹果EFI自动化配置?

如何用OpCore-Simplify在30分钟内完成黑苹果EFI自动化配置? 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 黑苹果(Hackintosh…...

7步解锁小米摄像机完整功能:yi-hack-v3固件终极指南

7步解锁小米摄像机完整功能:yi-hack-v3固件终极指南 【免费下载链接】yi-hack-v3 Alternative Firmware for Xiaomi Cameras based on Hi3518e Chipset 项目地址: https://gitcode.com/gh_mirrors/yi/yi-hack-v3 小米摄像机yi-hack-v3固件是一款专为海思Hi35…...

ZYNQ实战:AXI4-Stream FIFO跨时钟域传输的5个关键配置(附ADDA实验代码)

ZYNQ实战:AXI4-Stream FIFO跨时钟域传输的5个关键配置(附ADDA实验代码) 在FPGA开发中,跨时钟域数据传输一直是工程师面临的棘手问题之一。特别是当系统需要处理高速数据流时,如何确保数据在不同时钟域间安全、高效地传…...

Qwen3-0.6B-FP8在微信小程序开发中的应用:打造智能客服助手

Qwen3-0.6B-FP8在微信小程序开发中的应用:打造智能客服助手 你有没有遇到过这种情况?在小程序里买东西或者咨询问题,客服要么半天不回,要么就是机械的自动回复,问东答西,体验特别差。对于小程序开发者来说…...

如何高效优化Windows 11:5个实用技巧全面提升系统性能

如何高效优化Windows 11:5个实用技巧全面提升系统性能 【免费下载链接】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 cu…...

FaceFusion镜像部署:一键运行,免配置快速体验AI换脸

FaceFusion镜像部署:一键运行,免配置快速体验AI换脸 1. 什么是FaceFusion FaceFusion是当前最先进的AI换脸工具之一,它通过深度学习技术实现了高质量的人脸替换功能。与传统的换脸工具相比,FaceFusion具有以下显著优势&#xff…...

IDM激活终极指南:开源脚本完整解决方案与快速配置方法

IDM激活终极指南:开源脚本完整解决方案与快速配置方法 【免费下载链接】IDM-Activation-Script IDM Activation & Trail Reset Script 项目地址: https://gitcode.com/gh_mirrors/id/IDM-Activation-Script IDM(Internet Download Manager&am…...

光场相机入门:Macro Pixel与SAI如何让普通照片秒变3D(附Lytro实操指南)

光场相机实战:用Macro Pixel和SAI技术玩转3D摄影 想象一下,拍完照片后还能随意调整焦点、改变视角,甚至生成3D模型——这不是科幻电影,而是光场相机带来的真实体验。作为摄影技术的一次革命,光场相机通过独特的硬件设计…...

为什么你的Mac需要Scroll Reverser:解决多设备滚动混乱的终极方案

为什么你的Mac需要Scroll Reverser:解决多设备滚动混乱的终极方案 【免费下载链接】Scroll-Reverser Per-device scrolling prefs on macOS. 项目地址: https://gitcode.com/gh_mirrors/sc/Scroll-Reverser 你是否曾经在MacBook触控板和外接鼠标之间切换时&a…...

AI对话新玩法:用Nanbeige像素冒险终端,体验“勇者与大贤者”的复古聊天

AI对话新玩法:用Nanbeige像素冒险终端,体验"勇者与大贤者"的复古聊天 1. 复古像素风AI对话体验 在AI对话工具日益同质化的今天,Nanbeige 4.1-3B像素冒险终端带来了一股清新之风。这个独特的对话界面将现代AI技术与复古游戏美学完…...

2025届最火的五大降重复率网站横评

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 经过用心地对文本结构加以调整,伴随巧妙地进行措辞处理,能够切切实实…...

SparkFun SPI SerialFlash库深度解析:嵌入式Flash驱动开发指南

1. SparkFun SPI SerialFlash Arduino 库深度解析:面向嵌入式工程师的串行 Flash 驱动开发指南串行 Flash 存储器(Serial Flash)是嵌入式系统中不可或缺的非易失性数据载体,广泛应用于固件存储、配置参数保存、日志记录、OTA 升级…...

MAA明日方舟小助手:基于智能图像识别的游戏自动化革命

MAA明日方舟小助手:基于智能图像识别的游戏自动化革命 【免费下载链接】MaaAssistantArknights 《明日方舟》小助手,全日常一键长草!| A one-click tool for the daily tasks of Arknights, supporting all clients. 项目地址: https://git…...

别再只盯着mAP了!手把手教你用mmdetection打印每个类别的AP(附iou=0.5的精准调参)

深度解析mmdetection类别级AP分析:从指标解读到调参实战 在目标检测任务中,我们常常陷入一个思维定式——过度依赖mAP(mean Average Precision)这一全局指标来评判模型优劣。这就像仅凭GDP评价一个国家的发展水平,虽然…...

IRISMAN:PlayStation 3跨平台备份管理架构深度解析

IRISMAN:PlayStation 3跨平台备份管理架构深度解析 【免费下载链接】IRISMAN All-in-one backup manager for PlayStation3. Fork of Iris Manager. 项目地址: https://gitcode.com/gh_mirrors/ir/IRISMAN IRISMAN作为PlayStation 3平台的开源备份管理器&…...

Steam游戏DLC完整解锁指南:3步掌握SmokeAPI终极技巧

Steam游戏DLC完整解锁指南:3步掌握SmokeAPI终极技巧 【免费下载链接】SmokeAPI Legit DLC Unlocker for Steamworks 项目地址: https://gitcode.com/gh_mirrors/smo/SmokeAPI 你是否曾看着心爱的游戏DLC列表,却因预算有限而望而却步?或…...

电赛备赛避坑指南:从STM32到K210,如何根据题目灵活调整你的技术栈?

电赛备赛避坑指南:从STM32到K210的技术栈选择策略 全国大学生电子设计竞赛(电赛)是检验学生电子系统设计能力的顶级赛事。面对复杂的赛题要求,如何在有限时间内做出最优技术决策,往往决定了最终成绩。本文将从实际参赛…...

2026届毕业生推荐的降重复率平台实测分析

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek AI论文查重技术依托自然语言处理跟深度学习模型,借助语义分析、句式结构比对以及…...

保姆级教程:手把手调试LVGL 8.1的界面更新问题(从标记无效区域到flush的完整追踪)

LVGL界面更新问题深度排查指南:从标记无效区域到屏幕刷新的全链路追踪 当你在LVGL项目中点击按钮后,某个控件却像被冻住一样毫无反应——这种界面更新问题几乎每个嵌入式GUI开发者都遇到过。本文将带你深入LVGL 8.1的渲染管线,建立一套系统化…...

保姆级教程:零基础部署FLUX.2-Klein-9B,轻松实现AI智能图片修改

保姆级教程:零基础部署FLUX.2-Klein-9B,轻松实现AI智能图片修改 你是不是也遇到过这些情况?看到一张喜欢的衣服,想“穿”在自己照片上试试效果,却不会用复杂的修图软件。想给产品图换个背景,或者给模特衣服…...

2026届学术党必备的六大降AI率网站实际效果

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 第一步努力呈现,先去调整句式结构,要避免那种过于工整的排比还有重复…...

3小时从文字到视频:TaleStreamAI 重新定义AI小说推文创作自由

3小时从文字到视频:TaleStreamAI 重新定义AI小说推文创作自由 【免费下载链接】TaleStreamAI AI小说推文全自动工作流,自动从ID到视频 项目地址: https://gitcode.com/gh_mirrors/ta/TaleStreamAI 在数字内容创作的新时代,TaleStreamA…...

AI配音、AI作曲零基础快速上手

AI配音、AI作曲零基础快速上手📝 本章学习目标:通过本章学习,你将全面掌握"AI配音、AI作曲零基础快速上手"这一核心主题,建立系统性认知。一、引言:为什么这个话题如此重要 在人工智能快速发展的今天&#x…...

人工智能提示词场景篇:批判性思维学习

场景篇:批判性思维学习📝 本章学习目标:掌握场景篇:批判性思维学习中高效使用提示词的方法和技巧。一、引言 场景篇:批判性思维学习是提示词应用的重要场景之一。本章将系统讲解如何在该领域高效使用提示词。 ✅ 核心应…...

如何快速掌握猫抓浏览器扩展:专业用户的终极资源嗅探方案

如何快速掌握猫抓浏览器扩展:专业用户的终极资源嗅探方案 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 还在为网页视频无法下载而烦恼…...

二极管的温度特性

二极管的温度特性 例题 温度升高时,二极管的正向导通压降是 © A. 变大 B. 不变 C. 变小 正确答案:C 二极管的正向导通压降 (VDV_DVD​) 概念:当二极管正向偏置(P极接高电位,N极接低电位)时&#x…...