使用apktool + idea 调试smali

本文介绍了如何使用apktool反编译apk,然后在AndroidManifest.xml中添加调试配置,重打包并重签名。接着在IDEA中新建Java项目,将smali文件复制到src目录下,安装重签名的apk并通过`am`命令启动。通过DDMS获取调试端口,设置远程调试配置,最后在IDEA中设置断点并成功进行远程调试。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.使用apktool 反编译apk

java -jar apktool.jar -d d apkPath -o newPath

2.打开AndroidManifest.xml 在application节点上添加:

android:debuggable="true"

3.重打包apk,重签名

java -jar apktool.jar -d b newPath
java -jar signapk.jar platform.x509.pem platform.pk8 apk.apk apk_signed.apk

4.打开idea 新建java项目 将第一步反编译的smali目录下的内容 复制到src目录下
安装重签名后的apk,并以am方式启动

am start -D -W -n packageName/apckageName.MainActivity

5.打开ddms 查看被调试程序的端口

6.idea调试
1.新建远程调试:依次点击run-> edit configuration->“+”号->Remote
2.修改端口号和选择调试项目 保存
3.在src目录下 设置断点
4.点击run->debug 成功断下

ps:apktool 使用-d 打包后不能查看参数内容,可通过注入查看

原文参考:http://www.kanxue.com/bbs/showthread.php?t=195660

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值