HeidiSQL 数据库密码如何恢复

有时候我们会把数据库的连接密码保存在 HeidiSQL 中,但随着时间的流逝,我们可能希望重新找回保存在 HeidiSQL 中的密码,但 HeidiSQL 中保存的密码是无法被复制的。

2024-10-08_11-51-23

这时候,我们需要想办法找到原始的密码。

加密算法

HeidiSQL 中存储的密码使用了加密算法,但这个不是单向加密的,是可以恢复回来的。

使用下面的方法就可以找回原始密码。

  1. 打开 HeidiSQL and select File > Export Settings 把当前保存在 HeidiSQL 的配置导出成为文本。


2. 使用记事本打开导出的文本。
3. 在记事本打开的文本中,找到类似 755A5A585C3D8141 这样的字符串,并且把这个字符串先保存下来。

2024-10-08_11-55-09

  1. 拷贝下面的 HTML 代码到记事本中,然后修改后缀名为 html

<!doctype html>
<html>
<body>
<script>
function heidiDecode(hex) {
    var str = '';
    var shift = parseInt(hex.substr(-1));
    hex = hex.substr(0, hex.length - 1);
    for (var i = 0; i < hex.length; i += 2) 
        str += String.fromCharCode(parseInt(hex.substr(i, 2), 16) - shift); 
    return str; 
} 
document.write(heidiDecode('[ENCODED_PASSWORD]')); </script>
</body>
</html>
  1. 把从 HeidiSQL 到处的配置文件中有关密码的加密字符串,替换掉 [ENCODED_PASSWORD] 。
  2. 将上述的 HTML 文件保存,然后双击打开浏览器,在浏览器中就可以查看解密后的密码原文。

2024-10-08_11-58-05

上面代码的核心就是这个解密函数。

function heidiDecode(hex) {
    var str = '';
    var shift = parseInt(hex.substr(-1));
    hex = hex.substr(0, hex.length - 1);
    for (var i = 0; i < hex.length; i += 2) 
        str += String.fromCharCode(parseInt(hex.substr(i, 2), 16) - shift); 
    return str; 
} 

你也可以拷贝上面的代码到任何在线的 JS 编辑网站上,直接运行字符串就行。

为了简单的调试,我们嵌入这个 JavaScript 代码到:https://jsfiddle.net/xmzn6309/

2024-10-08_12-07-31

在这上面直接运行就好。

https://www.isharkfly.com/t/heidisql/16404

要在 Java 中操作 HeidiSQL 数据库,可以使用 Java Database Connectivity (JDBC) 驱动程序。以下是在 Java 中连接到 HeidiSQL 数据库的基本步骤: 1.下载并安装 HeidiSQL 2.下载并安装 MySQL Connector/J JDBC 驱动程序 3.在 Java 代码中加载 MySQL 驱动程序 4.使用 JDBC API 连接到 HeidiSQL 数据库 5.执行 SQL 查询和更新操作 以下是连接到 HeidiSQL 数据库并执行查询的示例代码: ``` import java.sql.*; public class HeidiSQLDemo { public static void main(String[] args) { try { // 加载 MySQL 驱动程序 Class.forName("com.mysql.jdbc.Driver"); // 连接到 HeidiSQL 数据库 Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydatabase", "username", "password"); // 创建 SQL 查询 String query = "SELECT * FROM mytable"; // 执行查询并获取结果 Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery(query); // 遍历结果集并输出结果 while (rs.next()) { String name = rs.getString("name"); int age = rs.getInt("age"); System.out.println("Name: " + name + ", Age: " + age); } // 关闭连接和资源 rs.close(); stmt.close(); conn.close(); } catch (Exception e) { e.printStackTrace(); } } } ``` 在这个示例中,我们使用了 MySQL Connector/J 驱动程序连接到 HeidiSQL 数据库,并执行了一个简单的 SELECT 查询。请确保将 "jdbc:mysql://localhost:3306/mydatabase" 替换为您自己的数据库连接字符串,并将 "username" 和 "password" 替换为您的数据库用户名和密码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HoneyMoose

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值