一.问题描述
Android 7.0 引入一项新的应用签名方案 APK Signature Scheme v2,先使用APK Signature Scheme v2签名打包,然后再使用python脚本打渠道包后,安装在7.0手机上出现如下问题:
二.原因
将APK直接当做zip解压,目录里会有一个不参与签名校验的META-INF目录,在META-INF目录内添加不同的空文件,可以唯一标识一个渠道。所以Python脚本打渠道包就是采用这种方式,每打一个渠道包只需复制一个apk,在META-INF中添加一个使用渠道号命名的空文件即可。 而APK Signature Scheme v2不允许对签名后的应用进行进一步的更改,提供更快的应用安装时间和更多针对未授权 APK 文件更改的保护。因此会出现上述问题。
三.解决方法
1.使用v1签名,禁用v2签名:
仅用传统方案签署,打开模块级 build.gradle 文件,然后将行 v2SigningEnabled false 添加到您的版本签名配置中:
android { ... defaultConfig { ... } signingConfigs { release { storeFile file("myreleasekey.keystore") storePassword "password" keyAlias "MyReleaseKey" keyPassword "password" v2SigningEnabled false } } }
或者在打包时:
使用上述方法打包后再使用python打渠道包,就不会出现此问题。
这种方法使用传统的v1签名,禁用了v2签名,不推荐使用。
2.使用gradle命令打包:
在Terminal窗口输入:gradlew assembleRelease就可以打出全部渠道包。
关于使用gradle命令打包的配置,此处不再说明。
参考:http://www.jianshu.com/p/44d40f8e67c9
缺点:渠道太多的话,速度慢。
3.使用美团的Walle库打包:
原理:在Apk中的APK Signature Block区块添加自定义的渠道信息来生成渠道包。
原理详见:http://tech.meituan.com/android-apk-v2-signature-scheme.html
使用方法详见:https://github.com/Meituan-Dianping/walle
其中打渠道包命令:
gradlew assemble{渠道号}ReleaseChannels
速度快,推荐使用。