【电子数据取证】微信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脚本精准截获打开数据库所需的密钥,并最终成功解密了数据库文件。在这个过程中,技术探索所带来的兴奋与成就感是显而易见的。然而,必须强调的是,所有技术操作都应仅用于教学目的。希望读者们在合法合规的基础上,谨慎运用这些技术,以确保尊重和保护他人的隐私与权利。

相关推荐
l5657589 分钟前
第五十五天(SQL注入&增删改查&HTTP头&UA&XFF&Referer&Cookie&无回显报错&复盘)
数据库
上海达策TECHSONIC14 分钟前
经验分享:如何让SAP B1数据库性能提升50%
运维·数据库·运维开发
言之。24 分钟前
深入解析Django重定向机制
数据库·django·sqlite
时序数据说30 分钟前
国内开源时序数据库IoTDB介绍
大数据·数据库·物联网·开源·时序数据库·iotdb
Databend1 小时前
CRC32 自包含退化现象分析
数据库
ITZHIHONH2 小时前
FastGPT源码解析 Agent知识库文本资料处理详解和代码分析
数据库·ai编程
小蒜学长3 小时前
基于Spring Boot的火灾报警系统的设计与实现(代码+数据库+LW)
java·数据库·spring boot·后端
福赖3 小时前
《MySQL基础——C 语言链接》
c语言·数据库·mysql
KIDAKN3 小时前
Redis 分布式锁
数据库·redis·分布式