安卓那档事02
安卓四大组件
组件 | 描述 |
---|---|
Activity(活动) | 在应用中的一个Activity可以用来表示一个界面,意思可以理解为“活动”,即一个活动开始,代表 Activity组件启动,活动结束,代表一个Activity的生命周期结束。一个Android应用必须通过Activity来运行和启动,Activity的生命周期交给系统统一管理。 |
Service(服务) | Service它可以在后台执行长时间运行操作而没有用户界面的应用组件,不依赖任何用户界面,例如后台播放音乐,后台下载文件等。 |
Broadcast Receiver(广播接收器) | 一个用于接收广播信息,并做出对应处理的组件。比如我们常见的系统广播:通知时区改变、电量低、用户改变了语言选项等。 |
Content Provider(内容提供者) | 作为应用程序之间唯一的共享数据的途径,Content Provider主要的功能就是存储并检索数据以及向其他应用程序提供访问数据的接口。Android内置的许多数据都是使用Content Provider形式,供开发者调用的(如视频,音频,图片,通讯录等) |
activity的切换
1 |
|
activity的生命周期
函数名称 | 描述 |
---|---|
onCreate() | 一个Activity启动后第一个被调用的函数,常用来在此方法中进行Activity的一些初始化操作。例如创建View,绑定数据,注册监听,加载参数等。 |
onStart() | 当Activity显示在屏幕上时,此方法被调用但此时还无法进行与用户的交互操作。 |
onResume() | 这个方法在onStart()之后调用,也就是在Activity准备好与用户进行交互的时候调用,此时的Activity一定位于Activity栈顶,处于运行状态。 |
onPause() | 这个方法是在系统准备去启动或者恢复另外一个Activity的时候调用,通常在这个方法中执行一些释放资源的方法,以及保存一些关键数据。 |
onStop() | 这个方法是在Activity完全不可见的时候调用的。 |
onDestroy() | 这个方法在Activity销毁之前调用,之后Activity的状态为销毁状态。 |
onRestart() | 当Activity从停止stop状态恢进入start状态时调用状态。 |

安卓动调
修改debug权限
1、修改AndroidManifest.xml
在AndroidManifest.xml添加可调试权限
1 |
|
2、XappDebug模块hook对应的app
3、Magisk命令(重启失效)
1 |
|
4、刷入MagiskHide Props Config模块(永久有效,但可能有的手机刷不上)
一般来说,在4选项中如果有ro.debuggable那就直接修改 没有的话就选5

开启adb调试
安卓版本号点击七次开启开发者模式并开启adb调试权限
Jeb调试
注意,Jeb调试要保证调试机和宿主机两端apk一致
CTRL+B 是下断点
在高版本安卓(8.1以上)中,会看不到大部分的寄存器:

像这里就只能进入到这个base64函数里面查看p1返回值寄存器了
Log插桩
定义:Log插桩指的是反编译APK文件时,在对应的smali文件里,添加相应的smali代码,将程序中的关键信息,以log日志的形式进行输出。
插入如下命令即可
1 |
|
将别人写的一个日志插桩的文件重命名为class2.dex,然后再插入命令即可。

最后使用工具(算法助手)捕获日志即可。
frida完爆
有一说一,这玩意一应该frida完爆吧。。。。
确实完爆,据某位不愿意透露姓名的安卓大神(已经给头像打码了)所说:

应该能做到执行到某个地方返回寄存器的值,回头试一试。
2023/11/6 更新
中午试了试:

分析知道是和最后的base64的返回值做比较,那就hook这个base64:

发现是自己写的base64,那就简单好hook了,hook脚本:
1 |
|
hook结果:

得到了base64。酷,这很符合我对frida的想像。
今天的安卓就学到这了(