Frida-objection 基础使用获取FLAG
本文为看雪论坛优秀文章
看雪论坛作者ID:shmilyaxy
【工具】jadx-gui静态分析、objection hook
一
程序基本分析
程序名称1.ab,不知道什么文件格式。
文件目录下通过file分析文件结构。
file *
【droid Backup】安卓备份文件,可以用ade.jer提取。
下载ade.jer,输入命令:
java -jar ade.jar unpack 1.ab 1.tar
将1.ab文件解释成1.tar文件。
解压tar文件:
tar xvf 1.tar
解压tar文件成apps文件夹。
文件夹内存在apk和数据库相关db文件等。
二
静态分析apk
使用jadx-gui静态分析apk。
手机安装apk,输入账号密码,点击登录,出现字符串,通过jadx-gui中字符串查找定位到函数中。
分析哪里调用该类:
发现是MainActivity类中的onClick方法调用:
仔细分析,onClick的逻辑和整体并没有太大关联,从MainActivity类入手,从onCreate方法开始分析。
【SharedPreferences】Android数据存储
参考链接:http://c.biancheng.net/view/3099.html
1.获取 SharedPreferences.Editor
调用 edit() 方法获取 SharedPreferences.Editor,SharedPreferences 通过该接口对其内容进行更新。
2.更新 SharedPreferences
通过 SharedPreferences.Editor 接口提供的 put 方法对 SharedPreferences 进行更新。
例如使用 putBoolean(String key, boolean value)、putFloat(String key, float value) 等方法将相应数据类型的数据与其 key 对应起来。
【a方法】
最终MainActivity类的onCreate方法中调用了本类的a方法。
【SQLiteDatabase】Android数据存储
在Activity中实例化自定义的DBHelper就可以通过getWritableDatabase方法获得对应的SQLiteDatabase对象,通过这个对象就可以对数据库进行增删改查操作了。
【ContentValues】
ContentValues 和HashTable类似都是一种存储的机制 但是两者最大的区别就在于,contenvalues只能存储基本类型的数据,像string,int之类的,不能存储对象这种东西,而HashTable却可以存储对象。
【this.b = new a(this, "Demo.db", (SQLiteDatabase.CursorFactory) null, 1);】
查看 a 继承自SQLiteOpenHelper类。
SQLiteOpenHelper类中方法getWritableDatabase():创建或打开可以读/写的数据库。
参考链接:https://cloud.tencent.com/developer/article/1394216
参考链接:SQlite数据库的加密与解密(https://www.jianshu.com/p/0b2376f3d579?u_atoken=47c0d7bb-640d-48da-be46-6b61f48f46b7&u_asession=01-zIqh8S4hJueZy1N3pBAmf0WurmliLnELFx2Kv7ATrngh6kUxhJw4Y5vyb5yLmn3X0KNBwm7Lovlpxjd_P_q4JsKWYrT3W_NKPr8w6oU7K9BweIxI0UVnrCOKV1Oi88FPpcarp92QKzyJKyYjREPlmBkFo3NEHBv0PZUm6pbxQU&u_asig=056p5cIcPIKtRzQlYqVpNFBZdsmgI5O79u5AanLSpiIhlHx6QpvlM2gt3IEEW0GPaNe_vVeLJGJHAWVhuvVaz88haRO5bzaWJag9VdOHAXqwGvX6EdRr6uuWFctUWRbCqN0olMulPaFxB0z9U9c15y9efpzZ4DlS-RBGhGUTxPRWj9JS7q8ZD7Xtz2Ly-b0kmuyAKRFSVJkkdwVUnyHAIJzfVwuRtx_QXYpgDBKbGnYxleKOBT3Eg2isneKdRDhVEAWPRPQyB_SKrj-61LB_f61u3h9VXwMyh6PgyDIVSG1W-kuCDvZ1h_9VG6XI7IaNLqGVjuvW8Mbnw36tryIj0GRqhXYhSLNr0p8RqzhmbvGvAi1oZNHaS10wUa5ZISNbKEmWspDxyAEEo4kbsryBKb9Q&u_aref=lvLondNlpzw%2B2O0aL9pmlScYTPE%3D)
【a方法中的关系总结】
【逻辑】
hook - getWritableDatabase方法,获取参数即可获取密码
主动调用getWritableDatabase方法==主动调用a方法
a方法是普通方法,需要类实例调用
三
objection hook获取密码
启动objection
objection -g com.xxx.xxx.xxx
hook getWritableDatabase方法(静态分析中知道该方法来自哪个类)
android hooking watch class_method net.sqlcipher.database.SQLiteOpenHelper.getWritableDatabase
--dump-args --dump-backtrace --dump-return
堆中搜索MainActivity类实例(因为调用他类中的a方法)
android heap search instances com.example.yaphetshan.tencentwelcome.MainActivity
调用a方法
android heap execute 0x60042a a
【获取密码】:ae56f99
四
解密数据库获取FLAG
需要使用DB.Browser.for.SQLite软件打开数据库。
下载链接:http://www.sqlitebrowser.org/blog/version-3-11-2-released/
Encryto.db加密数据
【补充下载连接:】
链接:https://pan.baidu.com/s/1y1LPrUHeVCyZT19DHveMsw
提取码:dbeo
看雪ID:shmilyaxy
https://bbs.pediy.com/user-home-941979.htm
# 往期推荐
球分享
球点赞
球在看
点击“阅读原文”,了解更多!
[广告]赞助链接:
关注数据与安全,洞悉企业级服务市场:https://www.ijiandao.com/
让资讯触达的更精准有趣:https://www.0xu.cn/
随时掌握互联网精彩
- 华为天才少年稚晖君被曝离职;苹果 A16“挤牙膏”原因曝光;Ruby 3.2.0 发布|极客头条
- CWPP第一|云上原生安全的一盘组合棋
- 下周五!全球首个元宇宙安全极客大会DEF CON 30 CHINA Party来袭
- 从零开始复现 DIR-815 栈溢出漏洞
- 扩展现实,打开新「视」界大门
- Change Buffer 只适用于非唯一索引页?错
- 如何营造专属你的企业技术影响力氛围感?
- 什么是EV SSL证书?
- 什么是代码签名证书
- 百度首批无人网约车开始运营;美团饿了么正式回应:已逐步取消对骑士逐单处罚;Qt 2021 路线图公布|极客头条
- Spring Boot 高效入门实战
- 免费的SSL证书管用吗?免费和收费的区别是什么?