分享

安卓从入门到进阶第十章(Smali调试)

 西北望msm66g9f 2019-10-18

Smali 是安卓 Apk 反编译出来的格式,类似于我们 PC 上面的汇编语言。


语法可以参考这个文章:

https://blog.csdn.net/yuanguozhengjust/article/details/80493963


PC 上的反编译调试工具用 ODIDA(这个也可以调试 Android ),我们这一节想说说 Android Studio 调试 Smali 的 方法。

为什么要做这个调试?我们按正常的逻辑是 Smali 文件转化成 java 去看,先看个大概,然后如果是运算之类的,我们有时候需要调试,不断验证变量值。那么调试就显得很重要。


先放之前的几个调试文章:

安卓从入门到进阶第四章(调试方法)

C 的调试

然后接下来我们补充 Smali 的调试,把 Android 上的调试策略讲完。

1 下载 Smalidea 包

从https:///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 中的按钮,就会在这里断下来。

剩下的就是你自由发挥了。

--完--

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多