apk逆向工程之方法数超上限65535(1)

前段时间为游戏出渠道包,当拿到游戏母包的时候,有点吃惊,1.6G;虽然现在的游戏普遍都这么大,但是我接过的包一般都是3、4百兆这样子的

接下来就是按照惯例打包了,自认为不会出什么问题,但是到回编译的时候,出现了一个很熟悉的错误,在写APP的时候遇到过,很多理论书籍上都写过得问题,方法数超上限(具体为什么超上限,为什么会是65535,可以看看相关资料,因为我不一定会写这方面的文章),Unsigned short value out of range:81325

(其实我也是查了半天才知道这个错误的意思)

既然是方法数超上限,那就需要用到分包了,首先确认母包中的Application(或者是我们提供给CP的中间jar中调用了MultiDex.install(this);最好使用的事反射,因为有的可能不需要分包,那么分包jar就不用打入其中)像这样:


接下来就是进入正题了,开始分包

经过讨论之后,首先确认,我们打入的渠道SDK不是母包必须依赖的,也就是说这些SDK可以放在classes2.dex中(中间jar通过反射获取渠道桥接文件,因为是反射所以不是必须依赖),还要一个就是,确保MultiDex.install(this);执行在任何一个classes2.dex中的任何一个类和方法调用之前调用就行了

接下来就简单了,只要将打包脚本改一下,将渠道SDK中的jar打入到classes2.dex中就可以了,当然,如果母包已经有多个classesx.dex,那就根据最高的数字+1生成一个新的

修改完毕之后,打包测试,正常运行(由于诸位的脚本可能各不相同,所以这里只讲了思路,没有直接上代码)

接下来上报提审的时候,出现了问题,UC包在上传的时候回检测包体中的有没有他的sdk,但是他只会检测classes.dex文件,所以这时候还是需要将ucSDK中的一些核心类文件放在classes.dex中,具体怎么做,需要看渠道的检测,然后将那些被检测的类文件放进去就行了(由于只有可别渠道会出现这些问题,所以协力就不细说了)

由于现在还没想到完美的分包方式,就是确保所有渠道都会通过的方式,所以这里文章就叫(1)了

提一下:如果发现渠道检测的文件加入classes.dex中之后还是出现了方法数超限的问题,那就需要CP方,那边讲母包分一下包了

总结:

简单来说就是安装Google说的那套,加入android.support.multidex.MultiDex包

然后在application中加入MultiDex.install(this);

之后将渠道SDK放入classes2.dex中就行了

当然这一切都是都是用脚本实现的了,至于其中一些具体细节,回编译,jar转dex等,我就姑且认为诸位都会了,因为不会这些是打不出渠道包的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
关于64 k引用限制 Android应用程序(APK)在Dalvik可执行文件的形式包含可执行的字节码文件(DEX)文件,其中包含已编译的代码来运行你的应用程序。Dalvik可执行规格限制一个Dex文件包含65536个方法:包括Android框架方法、Library方法的总数、和你自己的代码方法总数。因为65536等于64×1024,这一限制被称为“64k引用限制”。 这个极限就要求我们配置应用程序的构建过程,需要生成多个DEX文件,所以称为multidex 配置。 分析原因与注意事项 解决方法Android 5.0及以上系统和5.0以下系统怎么做。客官们不要着急,先看我一个个分析原因,毕竟我要装下逼哈哈。 一、Android 5.0以下的版本 Android 5.0(API leve 21)之前的系统使用Dalvik执行应用程序代码。默认情况下,Dalvik限制一个apk只有一个Dex文件。为了绕过这个限制, 我们可以使用multidex support library,它成为我们APK的主要DEX文件的一部分,负责管理我们APK访问其他DEX文件和代码。 注意: 如果咱的项目minSdkVersion是20或更低,运行到Android 4.4(API leve 20)或者更低版本的设备上时需要禁用AndroidStudio的即时运行 二、Android 5.0和更高版本 Android 5.0(API leve 21)和更高的系统使用runtime是ART ,原生支持从应用的apk文件加载多个DEX文件。ART在安装应用时预编译应用程序,会扫描多个classes(..N).dex文件编译成一个.oat的文件。更多Android5.0 runtime的更多信息,请参见即时运行-instant-run。 注意: 如果你使用即时运行 , AndroidStudio自动配置你的应用程序,你应用程序的minSdkVersion应该设置为21或更高。因为即时只工作在你APP的Debug版本,你任然需要配置你的release版本构建时用multidex避免64k的限制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值