首页
社区
课程
招聘
[原创]钉钉PC版数据库解密算法分析
2019-11-1 16:34 14324

[原创]钉钉PC版数据库解密算法分析

2019-11-1 16:34
14324

1. 解密过程分析

CreateFile 下条件断点,在打开数据库文件时 断下后查看堆栈,调用来至mainframe.dll

查看sqlite 源码,在  openDatabase 函数有以上的代码段,直接  用 ida 在  mainframe.dll 搜索 字符串 "temp",查找引用,定位到  openDatabase 函数


x64dbg 下断点,成功断下


跳出此函数,往下运行,停在疑似设置数据库密码的位置


步入


call 4202420 就是设置密码

打开ida 分析  4202420


从密钥里取16  byte 作为 AES-128 的 key  分别初始化 encrypt_key 和 decrypt_key 保存在

encrypt_cb_func_user_data ,encrypt_cb_func 会在解密数据库页面时被调用

encrypt_cb_func  的ida 代码如下


xx_cipher_callback_read

数据库 页面分块aes 解密, 在 aes_decrypt 下断,


在 上面的while 循环结尾断下后


可以看到 sqlite 文件头

2  密钥的生成分析

在上面设置密钥处进行回溯,很容易找到 密钥的生成 的相关代码

在目录 C:\Users\Administrator\AppData\Roaming\DingTalk下有两类数据库文件

globalStorage 子目录下的storage.db

{uid}_v2\DBFiles 子目录下的storage.db\dingtalk.db

storage.db  的密码生成

cpuid 0 的 四个整数 %d%d%d%d格式化成字符串


dingtalk.db 就是 uid 的MD5 值

 


代码:附件 dingding_db.cpp


[CTF入门培训]顶尖高校博士及硕士团队亲授《30小时教你玩转CTF》,视频+靶场+题目!助力进入CTF世界

最后于 2019-11-1 16:36 被欧阳brother编辑 ,原因:
上传的附件:
收藏
点赞3
打赏
分享
最新回复 (4)
雪    币: 1535
活跃值: (695)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
开花的水管 2019-11-1 18:52
2
0
666,赶紧保存
雪    币: 5925
活跃值: (4502)
能力值: ( LV10,RANK:160 )
在线值:
发帖
回帖
粉丝
淡然他徒弟 1 2019-11-2 01:03
3
0
mark
雪    币:
能力值: ( LV1,RANK:0 )
在线值:
发帖
回帖
粉丝
mb_xyoqljpt 2020-5-16 16:15
4
0
有没有大神研究下安卓app钉钉的sqlite密钥生成方式?
雪    币: 3246
活跃值: (339)
能力值: (RANK:20 )
在线值:
发帖
回帖
粉丝
blowfish 2022-3-24 17:20
5
0
猛男
游客
登录 | 注册 方可回帖
返回