安卓逆向--修改smali

和上一篇帖子用的工具一样 Android逆向助手 v2.2

 

这里只是做一个嵌入smali的测试,嵌入的东西很简单,只想在所有的activity里面弹出一段提示。

源码:
Toast.makeText(this, "----", Toast.LENGTH_LONG).show();

 

大致步骤:
1、解压目标apk,查看smali文件,找到要嵌入的位置。
大致是找BaseActivity、MainActivity等的onCreate方法,在setCOntentView方法之后紧跟一行,基本不会错。
2、获取提示的smali源码,写一个空工程,只有弹出提示的一行代码,方便获取smali,然后反编译,把对应smali代码取出来。
这里做一个对比:
java:
Toast.makeText(this, "----", Toast.LENGTH_LONG).show();

smali:

const-string v0, "----"
const/4 v1, 0x1
invoke-static {p0, v0, v1}, Landroid/widget/Toast;->makeText(Landroid/content/Context;Ljava/lang/CharSequence;I)Landroid/widget/Toast;
move-result-object v0
invoke-virtual {v0}, Landroid/widget/Toast;->show()V

 

大致是把变量、声明先提取出来,方法一个个分解开来。
3、将这段smali源码拷贝到指定位置,然后重新打包。记住需要签名。
整个过程要小心,不能乱了行,测试通过,达到预先的设想。
最后,既然可以放Toast,也可以放其他的代码了,各位尽情发挥!

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。