【电子数据取证】微信8.0.50版本数据库解密

文章关键词:电子数据取证、手机取证、微信取证、数据库解密

通过对8.0.50这一特定版本的分析,我们期望揭示软件迭代背后的逻辑思考,以及安全策略的演进方向。这不单纯是对技术细节的揭秘,更是一次关于未来通信安全趋势的展望,助力行业内外人士更好地理解数据加密的现实意义与潜在挑战。

本文以教学为基准、本文提供的可操作性不得用于任何商业用途和违法违规场景。

本人对任何原因在使用本人提供的代码和策略时可能对用户自己或他人造成的任何形式的损失和伤害不承担责任。

二、所使用的主要工具及版本

微信app 8.0.50

Frida 16.1.11

Jadx 1.5.0

MuMu模拟器 3.8.24

DB Browser for SQLite 3.12.2

三、分析过程及实现

想要进行微信数据库的逆向必须先了解其采用的是何种数据库及采用的防护手段!

Android中的SQLite是一种轻量级的关系型数据库,它是Android平台中默认的本地数据库存储解决方案。SQLite在Android系统中广泛使用,可用于存储和检索应用程序中的数据。

然而,SQLite却有一个致命的缺陷:不支持加密。因此存储在SQLite中的数据可以被任何人轻易地查看。所以,需要在开发应用时对数据库进行加密,目前对SQLite有两种加密方式:

1、对写入数据库的数据进行加密

2、对整个数据库文件进行加密

而微信所采取的方式便是第二种:对整个数据库文件进行加密。微信的数据库位于本地的/data/data/com.tencent.mm/MicroMsg/

66d9 xxxxxxxxxxa7目录下,名称为:EnMicroMsg.db,最后一个文件夹每个手机都不一样,需要自己找一下:

将其导出后用DB Browser for SQLite打开:

可以看到,需要输入密钥才能查看文件。那我们现在的目标就是获取数据库的密钥。

腾讯有着自己的app加固方案(腾讯乐固),但对微信查壳发现并没有加壳:

猜测原因是加壳后会影响使用性能,而微信这么一个全国几亿人在用的软件对性能的要求出不了一丝偏差。

用jadx加载APK,对SQLite有所了解的应该都知道,他有着自己所定义的api,要想对其进行操作必定会用到SQLiteDatabase这个类,搜索可得:

双击进入后,查找open函数,查看open函数的具体实现:

调用open函数打开数据库时,必然需要密钥。观察open函数的参数,第一个参数类型为byte数组,比较可疑。使用frida编写hook脚本:

function main() {

Java.perform(function () {

console.log("\nHook Start!");

var SQLiteDatabase = Java.use("com.tencent.wcdb.database.SQLiteDatabase");

SQLiteDatabase["open"].implementation = function (bArr, sQLiteCipherSpec, i15) {

console.log('open is called' + ', ' + 'bArr: ' + JSON.stringify(bArr) + ', ' + 'sQLiteCipherSpec: ' + sQLiteCipherSpec + ', ' + 'i15: ' + i15);

var ret = this.open(bArr, sQLiteCipherSpec, i15);

console.log('open ret value is ' + ret);

return ret;

}

});

}

setImmediate(main);

打开微信进行hook,结果如下:

将barr转成ascii码得到字符串"2248874",用SQLiteStudio解密数据库,解密算法配置为:

PRAGMA cipher_compatibility = 3;

PRAGMA cipher_use_hmac = OFF;

PRAGMA cipher_page_size = 1024;

PRAGMA kdf_iter = 4000;

至此,成功解密数据库。

四、总结

这篇文章记录了微信8.0.50版本数据库的解密过程,旨在为技术爱好者提供一个学习的参考。从介绍主要工具和SQLite数据库的加密方式入手,逐步分析微信应用的代码,通过Frida脚本精准截获打开数据库所需的密钥,并最终成功解密了数据库文件。在这个过程中,技术探索所带来的兴奋与成就感是显而易见的。然而,必须强调的是,所有技术操作都应仅用于教学目的。希望读者们在合法合规的基础上,谨慎运用这些技术,以确保尊重和保护他人的隐私与权利。

相关推荐
2301_7662834412 分钟前
Golang怎么实现防重复提交_Golang如何用Token机制防止表单重复提交【技巧】
jvm·数据库·python
qq_4142565712 分钟前
CSS如何实现元素在容器内居中_利用margin-auto技巧
jvm·数据库·python
2401_8242226913 分钟前
如何用 Transferable 对象零拷贝转移超大数组内存给子线程
jvm·数据库·python
SilentSamsara14 分钟前
Python 并发基础:threading/GIL 与 multiprocessing 的选型逻辑
服务器·开发语言·数据库·vscode·python·pycharm
m0_4954964114 分钟前
如何禁用 Vite 中的热更新(HMR)以避免 React 应用加载中断
jvm·数据库·python
m0_7411733315 分钟前
MySQL中如何使用CAST实现类型转换_MySQL数据类型转换技巧
jvm·数据库·python
qq_4135020215 分钟前
如何用 bubbles 属性让自定义事件穿透多个 Web Components
jvm·数据库·python
地球资源数据云16 分钟前
2015年中国30米分辨率沼泽湿地空间分布数据集
大数据·数据结构·数据库·人工智能·机器学习
2301_7756398917 分钟前
如何修改Oracle服务器默认的日期格式_NLS_DATE_FORMAT全局配置
jvm·数据库·python
2401_8314194418 分钟前
React 中父子组件函数传递的正确调用方式
jvm·数据库·python