和上一篇帖子用的工具一样 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,也可以放其他的代码了,各位尽情发挥!
时间: 2024-10-11 13:14:29