解决Navicat数据库连接成功但密码忘记的问题

 更新时间:2023年08月31日 11:36:34   作者:Covarde.H  
这篇文章给大家介绍了Navicat数据库连接成功,密码忘记如何解决,文中给大家介绍了两种解决方法,有详细的图文讲解,需要的朋友可以参考下

解决方法

一:通过注册表找到数据库连接的密码,再通过PHP解密

具体操作:

1.用 win + R 快捷键打开运行窗口,输入 regedit 打开注册表

2.在注册表地址栏输入下面内容,查找Navicat密码保存位置,回车:

计算机\HKEY_CURRENT_USER\SOFTWARE\PremiumSoft\Navicat\Servers 

3.在servers目录下,找到需要找回密码的连接,鼠标左键点击,右侧下拉找到名称为 pwd 的一项,该项的数据即为密码。右键,点击修改,复制数据:

4.使用 https://tool.lu/coderunner/ 在线工具,对复制下来的密码15057D7BA390进行解密

5.将以下php解密代码复制到在线工具中,将复制的数据粘贴到代码的倒数第二行,点击执行,即可得到密码

PS:该工具首行不能空行,否则执行会报错;另外,在代码倒数五六行需要指定Navicat版本

<?php
namespace FatSmallTools;
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);
    }
}
use FatSmallTools\NavicatPassword;
//需要指定版本,11或12
//$navicatPassword = new NavicatPassword(12);
$navicatPassword = new NavicatPassword(11);
//解密
$decode = $navicatPassword->decrypt('15057D7BA390');
echo $decode."\n";

二:通过Navicat导出连接,找到连接密码,再通过PHP进行解密

具体操作:

1.打开Navicat,导航栏点击“文件”,点击“导出连接”,

2.选择自己需要找回密码的连接,并勾选左下角“导出密码”,点击“确定”

 3.打开导出的文件,找到Password这一项,将引号中的数据复制下来

4.打开并使用方法一步骤4.中的在线工具和代码,修改倒数第二行的内容为步骤三保存的数据833E4ABBC56C89041A9070F043641E3B,点击运行

PS:由于我使用的是Navicat 12,在这种方法中需要修改代码中倒数第五六行的版本,否则解析出来乱码

以上就是解决Navicat数据库连接成功但密码忘记的问题的详细内容,更多关于Navicat数据库密码忘记的资料请关注脚本之家其它相关文章!

相关文章

  • 详解数据库中跨库数据表的运算

    详解数据库中跨库数据表的运算

    跨库数据表,是指逻辑上同一张数据表被分别存储在不同数据库中。接下来通过本文给大家介绍数据库中跨库数据表的运算方法,感兴趣的朋友跟随小编一起看看吧
    2018-11-11
  • MyISAM与InnoDB索引实现对比详解

    MyISAM与InnoDB索引实现对比详解

    这篇文章主要给大家介绍了关于MyISAM与InnoDB索引实现对比的相关资料,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • postgresql sql批量更新记录

    postgresql sql批量更新记录

    向postgresql中利用sql批量跟新记录的实现代码。
    2009-07-07
  • 利用带关联子查询Update语句更新数据的方法

    利用带关联子查询Update语句更新数据的方法

    这篇文章主要介绍了利用带关联子查询Update语句更新数据的方法,需要的朋友可以参考下
    2014-08-08
  • 得物基于StarRocks的OLAP需求实践详解

    得物基于StarRocks的OLAP需求实践详解

    这篇文章主要为大家介绍了得物基于StarRocks的OLAP需求实践详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • Navicat快速导入和导出sql文件的方法

    Navicat快速导入和导出sql文件的方法

    Navicat是MySQL非常好用的可视化管理工具,功能非常强大,能满足我们日常数据库开发的所有需求。今天教大家如何导入和导出SQL文件,感兴趣的朋友跟随小编一起看看吧
    2021-05-05
  • MySQL与Oracle 差异比较之四条件循环语句

    MySQL与Oracle 差异比较之四条件循环语句

    这篇文章主要介绍了MySQL与Oracle 差异比较之四条件循环语句,需要的朋友可以参考下
    2017-04-04
  • 梧桐数据库与`mysql`及`oracle`关于交换服务器编号的`SQL`写法分析(推荐)

    梧桐数据库与`mysql`及`oracle`关于交换服务器编号的`SQL`写法分析(推荐)

    本文介绍了如何通过SQL查询实现服务器编号的交换操作,以优化数据中心内部服务器的布局,文章说明了不同数据库(如梧桐数据库、MySQL和Oracle)的建表语句、数据插入以及SQL实现思路,通过具体的SQL查询,文章展示了如何在不同数据库中交换服务器编号,并解释了每个部分的功能
    2024-11-11
  • dba_indexes视图的性能分析

    dba_indexes视图的性能分析

    前端时间,在监控系统中加入了index的状态是否为unusable,以及其并行度是否有设置的监控:
    2008-08-08
  • dbeaver批量导出数据到另一个数据库的详细图文教程

    dbeaver批量导出数据到另一个数据库的详细图文教程

    DBeaver是一款数据库管理软件,小巧易用,最主要其官方版就可以满足平常得任务需求,这篇文章主要给大家介绍了关于dbeaver批量导出数据到另一个数据库的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2024-03-03

最新评论