【转载】Android inject详解


QQ群里有人冒出了这个名词,表示没听过,如此big tiger高大上的样子,特去查了一下资料,果然高大上啊,这样的有用贴留给自己,你值得拥有生气




注:本文转载自http://shensy.iteye.com/blog/1484798




本篇Blog源于我在上一家互联网公司工作中的一项任务,前几天原来公司的一个同事让我整理个文档出来学习一下。

今天写完文档后我决定再分享到Blog上一份。希望对需要的人有所帮助,或者能够激发读者的创意。

(本文为原创。如需转载,请勿修改,且注明作者shensy及出处:http://shensy.iteye.com/blog/1484798)

-------------------------------------------------------------------




1、

将你要注入的apk包放在相同路径下如(下面的Apk是我随便找的一个游戏):

E:\apk\apktool\Dino.v1.2_signed.apk

在cmd中将命令行切换到E:\apk\apktool\下。

执行:apktool d E:\apk\apktool\Dino.v1.2_signed.apk shensy

执行之后,会看到apk解包并生成了shensy文件夹。




2、

(1)在AndroidManifest.xml中,找到主界面类(步骤略过),这里是com.kongzhong.dino_zhcn.DinoGameNoAdsActivity。

(2)进入smali文件夹,将你需要注入的界面的smali文件复制到里面:

进入shensy\smali文件夹,将你需要注入的界面的smali文件复制到里面:比如你的界面是ehook.apk,你使用apktool解包ehook.apk后,取出其中界面类的smali程序复制到Dino.v1.2_signed.apk生成的shensy\smali文件夹中。

(3)根据包路径找到DinoGameNoAdsActivity对应的smali文件DinoGameNoAdsActivity.smali,打开该文件。找到onresume方法,直接照下面写就行:

.method protected onResume()V

.locals 1

       .prologue

invoke-super  {p0}, Landroid/app/Activity;->onResume()V

const-string  v0, "${stringcontent}”

invoke-static  {p0, v0},

L${package/classname};->${methodname}(Landroid/app/Activity;Ljava/lang/String;)V

return-void

.end method

第1行修改寄存器的个数: .locals后面的值,在原来的值上加1即可(原来是0就改为1)。

第4行是要添加的内容:传入调用方法的字符串指令。

第5、6、7行其实是一行(这里太长了所以换行),注意不要换行,是要添加的内容:

${package/classname}是注入界面的类名后面的 ${methodname} 就是注入界面类调用的方法名,此处是静态方法(可以调用非静态方法)。

修改完以上内容后保存一下(注意使用editplus等编辑器保存后会生成一个tmp临时文件,一定要删掉)。




3、

在cmd中将命令行切换到E:\apk\apktool\下,执行:apktool b shensy

将刚才生成的shensy文件夹打包,如果成功会在shensy文件夹下找到一个dist目录,里面是打好的apk包。




4、

上面打好的包是未签名的包,需要用签名工具对apk签名(这里不再介绍)。

 (全文完)

 

PS:关于Android应用的注入,网上搜索了一下还有另外2篇资料(目前只看到这些,不断更新中):

(1)http://www.docin.com/p-201009356.html 这篇文档作者的注入思路感觉是直接通过dex注入,但没有写具体细节,个人感觉直接修改dex文件要对Dalvik虚拟机十分熟悉。

(2)http://bbs.sdapk.com/archiver/tid-485.html 这篇文章的作者通过代码注入的方式打印出序列号,不错的文章。但在工作中发现有些应用不修改寄存器的个数注入后的程序会出现异常。

最近补充:

(3)命令行打包编译.apk包含第三方.jar 的方法:

http://snmoney.blog.163.com/blog/static/440058201181011468397/  

(4)将jar文件与dex文件的转换:http://blog.csdn.net/huigezhang/article/details/6658029

(5)Android 命令行手动编译打包详解:http://jojol-zhou.iteye.com/blog/729254




简而言之,就是可以在没有源码的情况下修改程序逻辑。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
AndroidInjectAndroid 注解框架,以简化 Android 开发 目前完成的注解(持续增加中): @AINoTitle: 类注解, 只适用于Activity(需继承于AIActivity), 设置Activity不显示Title     @AIFullScreen: 类注解, 只适用于Activity(需继承于AIActivity), 设置Activity全屏     @AILayout: 类注解         value[int]: 用于设置该Activity的布局 ---- setContentView(resId);     @AIView: 属性注解         id[int]: 用于绑定控件 ---- findViewById(resId);(default identifier[R.id.{field name}] if did not set id)         clickMethod[String]: 用于设置控件点击事件的回调方法, 可选, 方法名称任意, 参数必须为(View view)         longClickMethod[String]: 用于设置控件长按的回调方法, 可选, 方法名任意, 参数必须为(View view)         itemClickMethod[String]: 用于设置控件item点击的回调方法, 可选, 方法名任意, 参数必须为(AdapterView, View, int, long)         itemLongClickMethod[String]: 用于设置控件item长按的回调方法, 可选, 方法名任意, 参数必须为(AdapterView, View, int, long)     @AIBean: 属性注解, 为该属性生成一个对象并注入, 该对象必须有个默认的不带参数的构造方法     @AISystemService: 属性注解,为该属性注入系统服务对象     @AIClick: 方法注解         value[int[], 所要绑定控件的id]: 用于绑定控件点击事件的回调方法, 方法名称任意, 参数必须为(View view)     @AIItemClick: 方法注解         value[int[], 所要绑定控件的id]: 用于绑定控件item点击事件的回调方法, 方法名称任意, 参数必须为(AdapterView, View, int, long)     @AILongClick: 方法注解         value[int[], 所要绑定控件的id]: 用于绑定控件长按事件的回调方法, 方法名称任意, 参数必须为(View view)     @AIItemLongClick: 方法注解         value[int[], 所要绑定控件的id]: 用于绑定控件item长按事件的回调方法, 方法名称任意, 参数必须为(AdapterView, View, int, long)     @AIScreenSize: 属性注解         用于注入当前设备的屏幕大小(宽高)     @AIGet: 方法注解         value[String, 所要请求的url]:表示以GET来请求url         connTimeout[int, 连接超时时间]:连接一个url的连接等待时间         soTimeout[int, response返回超时时间]:连接上一个url,获取response的返回等待时间     @AIPost: 方法注解         value[String, 所要请求的url]:表示以Post来请求url         connTimeout[int, 连接超时时间]:连接一个url的连接等待时间         soTimeout[int, response返回超时时间]:连接上一个url,获取response的返回等待时间     @AIParam: 方法参数注解         value[String, 请求的参数别名]:注入@AIGet或@AIPost注解方法的请求参数     @AINetWorker: 属性注解         注入网络请求服务     @AIUpload: 方法注解         value[String, 所要请求的url]:表示要上传的url,默认用post请求(不需要使用@AIPost注解)         connTimeout[int, 连接超时时间]:连接一个url的连接等待时间         soTimeout[int, response返回超时时间]:连接上一个url,获取response的返回等待时间         注意:使用此注解的方法参数需要包含Collection或其子类型集合 或者包含File对象 来作为要上传的文件 使用fragment的注解,需要android-support-v4.jar的支持(以兼容低版本) 使用网络请求的注解,需要gson.jar的支持 使用文件上传的注解,需要httpmime.jar的支持
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值