这两个异常都是软件签名的问题
简介:
V1:应该是通过ZIP条目进行验证,这样APK 签署后可进行许多修改 - 可以移动甚至重新压缩文件。
V2:验证压缩文件的所有字节,而不是单个 ZIP 条目,因此,在签名后无法再更改(包括 zipalign)。正因如此,现在在编译过程中,我们将压缩、调整和签署合并成一步完成。好处显而易见,更安全而且新的签名可缩短在设备上进行验证的时间(不需要费时地解压缩然后验证),从而加快应用安装速度。
选择介绍:
- 只勾选v1签名:并不会影响什么,但是当版本高于7.0时就不会使用更安全的验证方式
- 只勾选V2签名:7.0版本以下会安装完显示未安装或安装包异常,7.0以上则使用了V2签名的方式验证
- 同时勾选V1和V2:兼容所有机型
解决方案:
同时选择v1和v2
或者通过build.gradle的android标签下的signingConfigs在自动化编译阶段实现V1和V2签名
signingConfigs {
debug {
v1SigningEnabled true
v2SigningEnabled true
}
release {
v1SigningEnabled true
v2SigningEnabled true
}
}