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

如何看navicat数据库连接的密码

一、版本问题
场景:在配置数据库连接后,忘记了数据库的密码,想要找回来。

其实有些版本(好像是低版本才有,具体哪个版本就没去研究了)在配置连接页面,是有个选项勾选是否显示密码的,有的话就简单了。

这里主要是介绍不能直接显示密码的版本,忘记密码后,如何进行查看密码(前提是你之前配置的是正确的!)。

二、不支持直接查看密码的版本,查看密码的步骤
第一步:导出链接,导出连接获取到 connections.ncx 文件
在这里插入图片描述

这里需要勾选 导出密码!!! 不然导出的文件里不包含加密的密码

在这里插入图片描述

第二步:找到加密密码,进行破解
在导出的connections.ncx文件中找到password,然后复制出来
在这里插入图片描述
找个在线执行php的网站(如果你本地有的话,也行),就找了一个:https://www.w3cschool.cn/tryrun/runcode?lang=php,
打开这个网址https://www.w3cschool.cn/tryrun/runcode?lang=php,把下面的代码复制进去,并且把倒数第三行换成你需要解密的密码

<?php
class NavicatPassword
{protected $version = 0;protected $aesKey = 'libcckeylibcckey';protected $aesIv = 'libcciv libcciv ';protected $blowString = '3DC5CA39';protected $blowKey = null;protected $blowIv = null;public function __construct($version = 12){$this->version = $version;$this->blowKey = sha1('3DC5CA39', true);$this->blowIv = hex2bin('d9c7c3c8870d64bd');}public function encrypt($string){$result = FALSE;switch ($this->version) {case 11:$result = $this->encryptEleven($string);break;case 12:$result = $this->encryptTwelve($string);break;default:break;}return $result;}protected function encryptEleven($string){$round = intval(floor(strlen($string) / 8));$leftLength = strlen($string) % 8;$result = '';$currentVector = $this->blowIv;for ($i = 0; $i < $round; $i++) {$temp = $this->encryptBlock($this->xorBytes(substr($string, 8 * $i, 8), $currentVector));$currentVector = $this->xorBytes($currentVector, $temp);$result .= $temp;}if ($leftLength) {$currentVector = $this->encryptBlock($currentVector);$result .= $this->xorBytes(substr($string, 8 * $i, $leftLength), $currentVector);}return strtoupper(bin2hex($result));}protected function encryptBlock($block){return openssl_encrypt($block, 'BF-ECB', $this->blowKey, OPENSSL_RAW_DATA|OPENSSL_NO_PADDING);}protected function decryptBlock($block){return openssl_decrypt($block, 'BF-ECB', $this->blowKey, OPENSSL_RAW_DATA|OPENSSL_NO_PADDING);}protected function xorBytes($str1, $str2){$result = '';for ($i = 0; $i < strlen($str1); $i++) {$result .= chr(ord($str1[$i]) ^ ord($str2[$i]));}return $result;}protected function encryptTwelve($string){$result = openssl_encrypt($string, 'AES-128-CBC', $this->aesKey, OPENSSL_RAW_DATA, $this->aesIv);return strtoupper(bin2hex($result));}public function decrypt($string){$result = FALSE;switch ($this->version) {case 11:$result = $this->decryptEleven($string);break;case 12:$result = $this->decryptTwelve($string);break;default:break;}return $result;}protected function decryptEleven($upperString){$string = hex2bin(strtolower($upperString));$round = intval(floor(strlen($string) / 8));$leftLength = strlen($string) % 8;$result = '';$currentVector = $this->blowIv;for ($i = 0; $i < $round; $i++) {$encryptedBlock = substr($string, 8 * $i, 8);$temp = $this->xorBytes($this->decryptBlock($encryptedBlock), $currentVector);$currentVector = $this->xorBytes($currentVector, $encryptedBlock);$result .= $temp;}if ($leftLength) {$currentVector = $this->encryptBlock($currentVector);$result .= $this->xorBytes(substr($string, 8 * $i, $leftLength), $currentVector);}return $result;}protected function decryptTwelve($upperString){$string = hex2bin(strtolower($upperString));return openssl_decrypt($string, 'AES-128-CBC', $this->aesKey, OPENSSL_RAW_DATA, $this->aesIv);}
};//需要指定版本两种,11或12
//$navicatPassword = new NavicatPassword(11);
//这里我指定的12的版本,原先指定的11,执行之后的密码是乱码
$navicatPassword = new NavicatPassword(12);//解密
//$decode = $navicatPassword->decrypt('15057D7BA390');
$decode = $navicatPassword->decrypt('复制出来的密码');
echo $decode."\n";
?>

在这里插入图片描述
如图得到了解析出来的密码,文章来自https://blog.csdn.net/weixin_41287260/article/details/141476859,我害怕原来博主删文章什么的,重新复制一份。

相关文章:

  • 光谱相机在地质勘测中的应用
  • 乘最多水的容器 | 算法 | 给定一个整数数组。有n条垂线。找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。
  • Java集合框架与三层架构实战指南:从基础到企业级应用
  • 堆的C语言实现
  • 复杂项目中通过使用全局变量解决问题的思维方式
  • 网工每日一练
  • WebRTC:实时通信的未来之路
  • OceanBase数据库全面指南(数据操作篇DML)
  • SpringBoot 2.X 版本整合 Swagger + Knife4j 接口文档
  • PyQt学习系列03-动画与过渡效果
  • 04-Web后端基础(基础知识)
  • 网络编程中的 Protobuf 和 JsonCpp 全面解析
  • [Vue]路径跳转和路由高级设置
  • Kubernetes上的爬虫排队术——任务调度与弹性扩缩容实战
  • Qt控件:显示控件
  • Python 实现Web 请求与响应
  • SpringBoot开发——Spring Boot异常处理全攻略:五大方案实战对比
  • Redis 5.0.10 集群部署实战(3 主 3 从,三台服务器)
  • 2025年系统架构师---综合知识卷
  • webpack构建速度和打包体积优化方案
  • ubuntu做网站/品牌推广活动有哪些
  • 网店代运营具体做什么/引擎优化seo怎么做
  • 建设服装网站的亮点/百度霸屏全网推广
  • 做海报的高清模板的网站/2023年10月疫情恢复
  • 外贸建站 台州/企业整站推广
  • 石景山广州网站建设/百度推广官网