Smali 是安卓 Apk 反编译出来的格式,类似于我们 PC 上面的汇编语言。
语法可以参考这个文章:
https://blog.csdn.net/yuanguozhengjust/article/details/80493963
PC 上的反编译调试工具用 OD 和 IDA(这个也可以调试 Android ),我们这一节想说说 Android Studio 调试 Smali 的 方法。
为什么要做这个调试?我们按正常的逻辑是 Smali 文件转化成 java 去看,先看个大概,然后如果是运算之类的,我们有时候需要调试,不断验证变量值。那么调试就显得很重要。
先放之前的几个调试文章:
安卓从入门到进阶第四章(调试方法)
C 的调试
然后接下来我们补充 Smali 的调试,把 Android 上的调试策略讲完。
1 下载 Smalidea 包
从https://bitbucket.org/JesusFreke/smali/downloads/
下载 smalidea-0.05.zip ,独立的 jar 包是反编译和打包工具,自己想研究可以下载看看,这里我们不用。
2 Android studio 安装 Smali 插件
File -- Settings 搜索 plugins 选择从Disk加载
3 下载反编译 Apk 工具 APKDB
从https://www.duote.com/soft/73200.html
下载下来安装就可以了。
4 反编译 Apk
拿到我们需要调试的 Apk ,选择 Apk,右键菜单,使用 APKDB 编译
一路回车就可以了。编译完会在当前目录下出来一个同名字的目录,就是反编译出来的内容。
然后删掉 original 目录。
5 将我们反编译出来的目录,导入 Android Studio.
选择我们的目录,一路下一步即可。
6 额外备注
当前我的手机是 ROOT 版本,Apk 不需要调试版本,直接安装运行起来。不是 ROOT 版本,就配置成调试版。(xml配置 android:debuggable="true")
7 开始调试
运行Apk,然后使用 Run -- Attach .... Process 选择我们的包名,点击确定即可。
然后在我们需要断下的地方,设置断点,这里设置在 onclick 方法里面。
$1 代表匿名类。然后我们点击 Apk 中的按钮,就会在这里断下来。
剩下的就是你自由发挥了。
--完--
安卓从入门到进阶第二篇(框架流程) 推荐你读: Android 系统各个版本上https的抓包Kotlin与Java的不同之处
扫一扫 关注我的公众号 如果你想要跟大家分享你的文章,欢迎投稿~