广告
返回顶部
首页 > 资讯 > 数据库 >如何查看Navicat加密的数据库密码
  • 474
分享到

如何查看Navicat加密的数据库密码

摘要

目录查看Navicat加密的数据库密码1、打开运行窗口,输入regedit,点击确认按钮,打开注册表编辑器2、在注册表中找到Navicat加密后的密码3、打开PHP在线运行工具,粘贴解密代码4. 修改倒数第三行Navic

查看Navicat加密的数据库密码

背景:本机装的Mysql数据库密码忘记了,打开了Navicat连接过数据库,不过密码是加密的,既然能加密那就能解密,哈哈哈哈。

解密后发现密码居然是password,好尴尬

1、打开运行窗口,输入regedit,点击确认按钮,打开注册表编辑器

如何查看Navicat加密的数据库密码

2、在注册表中找到Navicat加密后的密码

  • 展开【HKEY_CURRENT_USER】
  • 展开【Software】
  • 展开【PremiumSoft】
  • 展开【NavicatPG】
  • 展开【Servers】
  • 选择 【mysql
  • 右侧找到 pwd,双击并复制数值数据

如何查看Navicat加密的数据库密码

如何查看Navicat加密的数据库密码

如何查看Navicat加密的数据库密码

如何查看Navicat加密的数据库密码

3、打开php在线运行工具,粘贴解密代码

  • 工具地址:https://tool.lu/coderunner
  • 复制解密代码到工具中
<?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);
$navicatPassword = new NavicatPassword(12);
 
//解密
//$decode = $navicatPassword->decrypt('15057D7BA390');
$decode = $navicatPassword->decrypt('E75BF077AB8BAA3AC2D5');  // 替换成上一步的数据数值
echo $decode."\n";
?>

4. 修改倒数第三行NavicatPassword的版本值

5、更改倒数第二行decrypt()方法中的字符串为Navicat加密后的密码

6、点击执行,右侧得到解密后的密码

如何查看Navicat加密的数据库密码

附录:navicat找出加密的密码

  • Navicat(11.2.7、12.1.15、15.1.17、16.0.6上述版本均已通过测试
  • 进入注册表进行查询

使用【Win】+ 【R】组合快捷键,快速打开运行命令框,在打开后面键入命令:【Regedit】打开注册表编辑器

文件路径:

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

以Navicat16为例,通过上方路径,找到注册表中存储密码值的位置(如下图),选中要查看密码的连接名称,双击Pwd项,复制对应的值,至此获得了密文

如何查看Navicat加密的数据库密码

Navicat导出(推荐)

以Navicat16为例,菜单栏上点击文件,选择导出连接...,一定要选中导出密码!!!导出格式为*.ncx(该ncx本质上是XML文件,文件中包含连接的全部信息)

注:Navicat11版本没有勾选导出密码选项,直接导出即可;Navicat12+版本要勾选【导出密码】选项!

如何查看Navicat加密的数据库密码

如何查看Navicat加密的数据库密码

解密密文

Go

Https://www.nhooo.com/tool/Java8/

运行代码

Go

import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecreTKEySpec;
import javax.xml.bind.DatatypeConverter;
import java.NIO.charset.StandardCharsets;
import java.security.MessageDigest;
import java.util.Arrays;
public class Main {
    public static void main(String []args) {
//navicat11解密        Navicat11Cipher de = new Navicat11Cipher();
        System.out.println(de.decryptString("密文放此处"));
//navicat12+解密        Navicat12Cipher de12 = new Navicat12Cipher();
        System.out.println(de12.decryptString("密文放此处"));
    }
    static class Navicat11Cipher {
        public static final String DefaultUserKey = "3DC5CA39";
        private static byte[] _IV;
        private static SecretKeySpec _Key;
        private static Cipher _Encryptor;
        private static Cipher _Decryptor;
        private static void initKey(String UserKey) {
            try {
                MessageDigest sha1 = MessageDigest.getInstance("SHA1");
byte[] userkey_data = UserKey.getBytes(StandardCharsets.UTF_8);
                sha1.update(userkey_data, 0, userkey_data.length);
                _Key = new SecretKeySpec(sha1.digest(), "Blowfish");
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        private static void initChiperEncrypt() {
            try {
// Must use NoPadding                _Encryptor = Cipher.getInstance("Blowfish/ECB/NoPadding");
                _Encryptor.init(Cipher.ENCRYPT_MODE, _Key);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        private static void initChiperDecrypt() {
            try {
// Must use NoPadding                _Decryptor = Cipher.getInstance("Blowfish/ECB/NoPadding");
                _Decryptor.init(Cipher.DECRYPT_MODE, _Key);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        private static void initIV() {
            try {
byte[] initVec = DatatypeConverter.parseHexBinary("FFFFFFFFFFFFFFFF");
                _IV = _Encryptor.doFinal(initVec);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        private void xorBytes(byte[] a, byte[] b) {
for (int i = 0; i < a.length; i++) {
int aVal = a[i] & 0xff; // convert byte to integerint bVal = b[i] & 0xff;
                a[i] = (byte) (aVal ^ bVal); // xor aVal and bVal and typecast to byte            }
        }
        private void xorBytes(byte[] a, byte[] b, int l) {
for (int i = 0; i < l; i++) {
int aVal = a[i] & 0xff; // convert byte to integerint bVal = b[i] & 0xff;
                a[i] = (byte) (aVal ^ bVal); // xor aVal and bVal and typecast to byte            }
        }
        static {
            initKey(DefaultUserKey);
            initChiperEncrypt();
            initChiperDecrypt();
            initIV();
        }
        private byte[] Encrypt(byte[] inData) {
            try {
byte[] CV = Arrays.copyOf(_IV, _IV.length);
byte[] ret = newbyte[inData.length];
int blocks_len = inData.length / 8;
int left_len = inData.length % 8;
for (int i = 0; i < blocks_len; i++) {
byte[] temp = Arrays.copyOfRange(inData, i * 8, (i * 8) + 8);
                    xorBytes(temp, CV);
                    temp = _Encryptor.doFinal(temp);
                    xorBytes(CV, temp);
                    System.arraycopy(temp, 0, ret, i * 8, 8);
                }
if (left_len != 0) {
                    CV = _Encryptor.doFinal(CV);
byte[] temp = Arrays.copyOfRange(inData, blocks_len * 8, (blocks_len * 8) + left_len);
                    xorBytes(temp, CV, left_len);
                    System.arraycopy(temp, 0, ret, blocks_len * 8, temp.length);
                }
return ret;
            } catch (Exception e) {
                e.printStackTrace();
return null;
            }
        }
        public String encryptString(String inputString) {
            try {
byte[] inData = inputString.getBytes(StandardCharsets.UTF_8);
byte[] outData = Encrypt(inData);
return DatatypeConverter.printHexBinary(outData);
            } catch (Exception e) {
                e.printStackTrace();
return"";
            }
        }
        private byte[] Decrypt(byte[] inData) {
            try {
byte[] CV = Arrays.copyOf(_IV, _IV.length);
byte[] ret = newbyte[inData.length];
int blocks_len = inData.length / 8;
int left_len = inData.length % 8;
for (int i = 0; i < blocks_len; i++) {
byte[] temp = Arrays.copyOfRange(inData, i * 8, (i * 8) + 8);
                    temp = _Decryptor.doFinal(temp);
                    xorBytes(temp, CV);
                    System.arraycopy(temp, 0, ret, i * 8, 8);
for (int j = 0; j < CV.length; j++) {
                        CV[j] = (byte) (CV[j] ^ inData[i * 8 + j]);
                    }
                }
if (left_len != 0) {
                    CV = _Encryptor.doFinal(CV);
byte[] temp = Arrays.copyOfRange(inData, blocks_len * 8, (blocks_len * 8) + left_len);
                    xorBytes(temp, CV, left_len);
for (int j = 0; j < temp.length; j++) {
                        ret[blocks_len * 8 + j] = temp[j];
                    }
                }
return ret;
            } catch (Exception e) {
                e.printStackTrace();
return null;
            }
        }
        public String decryptString(String hexString) {
            try {
byte[] inData = DatatypeConverter.parseHexBinary(hexString);
byte[] outData = Decrypt(inData);
returnnew String(outData, StandardCharsets.UTF_8);
            } catch (Exception e) {
                e.printStackTrace();
return"";
            }
        }
    }
    static class Navicat12Cipher {
        private static SecretKeySpec _AesKey;
        private static IvParameterSpec _AesIV;
        static {
            _AesKey = new SecretKeySpec("libcckeylibcckey".getBytes(StandardCharsets.UTF_8), "AES");
            _AesIV = new IvParameterSpec("libcciv libcciv ".getBytes(StandardCharsets.UTF_8));
        }
        public String encryptString(String plaintext) {
            try {
                Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
                cipher.init(Cipher.ENCRYPT_MODE, _AesKey, _AesIV);
byte[] ret = cipher.doFinal(plaintext.getBytes(StandardCharsets.UTF_8));
return DatatypeConverter.printHexBinary(ret);
            } catch (Exception e) {
                e.printStackTrace();
return"";
            }
        }
        public String decryptString(String ciphertext) {
            try {
                Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
                cipher.init(Cipher.DECRYPT_MODE, _AesKey, _AesIV);
byte[] ret = cipher.doFinal(DatatypeConverter.parseHexBinary(ciphertext));
returnnew String(ret, StandardCharsets.UTF_8);
            } catch (Exception e) {
                e.printStackTrace();
return"";
            }
        }
    }
}

到此这篇关于如何查看Navicat加密的数据库密码的文章就介绍到这了,更多相关Navicat查看数据库密码内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: 如何查看Navicat加密的数据库密码

本文链接: https://www.lsjlt.com/news/201721.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何查看Navicat加密的数据库密码
    目录查看Navicat加密的数据库密码1、打开运行窗口,输入regedit,点击确认按钮,打开注册表编辑器2、在注册表中找到Navicat加密后的密码3、打开php在线运行工具,粘贴解密代码4. 修改倒数第三行Navic...
    99+
    2023-04-20
    Navicat查看数据库密码 Navicat数据库密码加密 Navicat密码加密
  • 【navicat 密码查看】小技巧navicat 如何查看密码
    时间久了,当我们以前连上了navicat 之后,密码忘记了,但是依然能连接,此时我们想查看密码,应该如何操作呢? 步骤1:点击navicat 文件选项,导出连接,勾选需要导出的数据库,导出的时候一定要...
    99+
    2023-08-31
    javascript php java
  • 在Navicat中查看已保存的数据库密码
    将数据库连接导出,导出时勾选密码。 将导出的文件用记事本打开,可以看到root账号下对应的密码已经被加密。 解密。 需要在下面的网址下,运行此PHP代码。 改最下面的密文即可。 网站连接:代码在线运行 - 在线工具 ...
    99+
    2023-09-06
    php mysql
  • 查看Navicat保存的密码
    在 Navicat 文件菜单中,选择导出连接,在弹出的窗口中,选择你要导出的连接名称,并在最下面勾选导出密码,然后点确认。 把导出的文件用文本查看器查看,里面有一段类似如下的代码: UserName...
    99+
    2023-08-31
    php
  • 查看Navicat已连接的密码
    查看Navicat已连接的密码 说明:有时可能我们早已忘记Navicat中已连接的密码了,但是这个密码我们还是有需要用到的。我们可以使用另外一种方式来把咱的密码获取的出来。 1、导出可以成功连接...
    99+
    2023-09-01
    php 数据库 sql
  • navicat如何修改数据库密码
    小编给大家分享一下navicat如何修改数据库密码,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!navicat修改数据库密码1....
    99+
    2022-10-18
  • navicat~导出数据库密码
    当我们mysql密码忘记了,而在navicat里有记录,我们应该如何导出这个密码呢? 第一步:文件菜单,导出链接,导出连接获取到 connections.ncx 文件 这里需要勾选 导出密码!!! 不然导出的文件里不包含加密的密码 ...
    99+
    2016-06-21
    navicat~导出数据库密码
  • Ubuntu怎么查看数据库密码
    在Ubuntu上查看数据库密码可以通过以下步骤:1. 打开终端。2. 以管理员身份运行以下命令登录到数据库服务器:```sudo m...
    99+
    2023-08-25
    ubuntu 数据库
  • 查看phpmyadmin数据库密码的方法
    这篇文章主要介绍了查看phpmyadmin数据库密码的方法,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。无法看到原来的密码,只可以查看到数据库用...
    99+
    2022-10-18
  • Android 使用sqlcipher加密和解密数据库(包括加密和解密已有的数据库,还有如何查看数据库教程)
    前言 我们知道Android系统有一个内嵌的SQLite数据库,并且提供了一整套的API用于对数据库进行增删改查操作,SQLite是一个轻量级的、跨平台的、开源的嵌入式数据库引擎,也是一个关系型的的使用SQL语句的数据库引擎,读写效率高、资...
    99+
    2023-10-22
    数据库
  • 如何查看redis数据库用户名密码
    要查看Redis数据库的用户名和密码,您可以使用以下步骤:1. 打开Redis配置文件。默认情况下,Redis的配置文件名为redi...
    99+
    2023-09-05
    redis数据库
  • Navicat中如何查看已连接保存的密码
    这篇文章主要为大家展示了“Navicat中如何查看已连接保存的密码”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Navicat中如何查看已连接保存的密码”这篇文...
    99+
    2022-10-19
  • springboot项目数据库密码如何加密
    前言 在我们日常开发中,我们可能很随意把数据库密码直接明文暴露在配置文件中,在开发环境可以这么做,但是在生产环境,是相当不建议这么做,毕竟安全无小事,谁也不知道哪天密码就莫名其妙泄...
    99+
    2022-11-12
  • 如何查看mysql密码root密码
    本人是个小白,经过实践得出win下mysql的root密码该如何查看,喜欢请收藏哦! 直接上干货!!! 第一步:关闭mysql服务,可以在cmd中关闭(命令:net sopt mysql),也可以直接到服务中关闭。 第二步:以管理员身份运行...
    99+
    2023-10-10
    mysql 数据库 database
  • edb数据库如何加密码
    给edb数据库设置密码的方法首先,打开并进入易语言编程软件;在软件界面中点击上方的“数据库”按钮,并在下拉中选择“结构编辑器”选项;进入结构编译器页面后,在界面中点击“置密码”按钮;在弹出的文件选择对话框中,选择需要设置密码的edb数据库,...
    99+
    2022-10-22
  • navicat怎么修改数据库密码
    navicat中修改数据库密码的方法:1、打开navicat工具;2、连接数据库;3、点击顶部“用户”菜单栏;4、选择需要修改密码的数据库用户进行编辑;5、最后在用户信息对话框中重新设置密码并点击“保存”使其生效即可。具体操作步骤:打开na...
    99+
    2022-10-11
  • 如何在Navicat中修改MySQL数据库的密码
    本篇文章为大家展示了如何在Navicat中修改MySQL数据库的密码,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。方法1: 用SET PASSWORD命令 首先登录...
    99+
    2022-10-18
  • 如何看云主机数据库的密码
    首先,我们需要了解云主机数据库的密码通常是加密存储的,无法直接查看。这是出于数据安全的考虑,以防止未经授权的访问和数据泄露。然而,您...
    99+
    2023-08-18
    云主机 数据库
  • phpstudy数据库如何添加密码
    为phpstudy数据库设置密码的方法首先,打卡并进入phpstudy软件界面;在phpstudy软件界面中,点击“启动”按钮;等待phpstudy启动后,在界面中点击“其他选项菜单”按钮,并在下拉中选择“MySQL工具”选项;选择MySQ...
    99+
    2022-10-10
  • 云主机如何看数据库密码
    通常,云主机中的数据库密码是存储在配置文件或环境变量中的。要查看数据库密码,可以按照以下步骤进行操作:1. 登录云主机:使用SSH等...
    99+
    2023-09-17
    云主机 数据库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作