Android签名打包V1和V2的区别

事情的起因

     昨天给修改app相关功能,Android Studio打包后进行更新,结果客户反馈有部分人升级失败!紧急检查发现有部分用户提示找不到证书,解包apk发现META-INF文件中缺少CERT.RSA,立即重新生成apk勾选V1 V2,替换原有文件;

签字证书描述:

Android 7.0中引入了APK Signature Scheme v2,v1是jar Signature来自JDK
V1:应该是通过ZIP条目进行验证,这样APK 签署后可进行许多修改 - 可以移动甚至重新压缩文件。
V2:验证压缩文件的所有字节,而不是单个 ZIP 条目,因此,在签名后无法再更改(包括 zipalign)。正因如此,现在在编译过程中,我们将压缩、调整和签署合并成一步完成。好处显而易见,更安全而且新的签名可缩短在设备上进行验证的时间(不需要费时地解压缩然后验证),从而加快应用安装速度。

 

结论

V1和V2的签名使用:

1.只勾选v1签名并不会影响什么,但是在7.0上不会使用更安全的验证方式。
2.只勾选V2签名7.0以下会直接安装完显示未安装,7.0以上则使用了V2的方式验证。
3.同时勾选V1和V2则所有机型都没问题。

昨天给修改app相关功能,Android Studio打包后进行更新,结果客户反馈有部分人升级失败!紧急检查发现有部分用户提示找不到证书,解包apk发现META-INF文件中缺少CERT.RSA,立即重新生成apk勾选V1 V2,替换原有文件;

签字证书描述:

Android 7.0中引入了APK Signature Scheme v2,v1是jar Signature来自JDK
V1:应该是通过ZIP条目进行验证,这样APK 签署后可进行许多修改 - 可以移动甚至重新压缩文件。
V2:验证压缩文件的所有字节,而不是单个 ZIP 条目,因此,在签名后无法再更改(包括 zipalign)。正因如此,现在在编译过程中,我们将压缩、调整和签署合并成一步完成。好处显而易见,更安全而且新的签名可缩短在设备上进行验证的时间(不需要费时地解压缩然后验证),从而加快应用安装速度。

 

结论

V1和V2的签名使用:

1.只勾选v1签名并不会影响什么,但是在7.0上不会使用更安全的验证方式。
2.只勾选V2签名7.0以下会直接安装完显示未安装,7.0以上则使用了V2的方式验证。
3.同时勾选V1和V2则所有机型都没问题。

你可能感兴趣的:(Android开发)