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

相关推荐
一个有温度的技术博主10 分钟前
Redis系列三:在linux上安装Redis
linux·数据库·redis
changhong198610 分钟前
redis批量删除namespace下的数据
数据库·redis·缓存
IvorySQL12 分钟前
PostgreSQL 技术日报 (3月18日)|从 MD5 到 SCRAM:PG 的安全转变
数据库·postgresql·开源
代码派24 分钟前
MySQL 慢 SQL 排查这件事,NineData 社区 VS DBeaver/ Navicat 技术分析
数据库·sql·mysql·navicat·数据库管理工具·dbeaver·数据库对比
白菜!!!1 小时前
SQL中IF、IFNULL、NULLIF、ISNULL函数的使用
数据库·sql·mysql
H_老邪1 小时前
redis 安装
数据库·redis·缓存
m0_743297421 小时前
Python在金融科技(FinTech)中的应用
jvm·数据库·python
霖霖总总1 小时前
[Redis小技巧17]深入解析 Redis 缓存穿透:原理、防御策略与布隆过滤器实践
数据库·redis·缓存
2401_857865232 小时前
Python日志记录(Logging)最佳实践
jvm·数据库·python
爱可生开源社区2 小时前
SCALE 二月榜单发布:新增三款国内外大模型,新增模型测评实验室!
数据库