欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

关于Android Studio 打包 V1 V2 签名的选择问题

程序员文章站 2022-12-25 17:30:21
前言 以前as打包都是填完key信息就ok了,as后面更新之后,打包的签名版本多了v1,v2选择,该如何选择呢? v1与v2的区别 android 7.0中引入了apk signature sche...

前言

以前as打包都是填完key信息就ok了,as后面更新之后,打包的签名版本多了v1,v2选择,该如何选择呢?

v1与v2的区别

android 7.0中引入了apk signature scheme v2,v1呢是jar signature来自jdk

v1:应该是通过zip条目进行验证,这样apk 签署后可进行许多修改 - 可以移动甚至重新压缩文件。

v2:验证压缩文件的所有字节,而不是单个 zip 条目,因此,在签名后无法再更改(包括 zipalign)。正因如此,现在在编译过程中,我们将压缩、调整和签署合并成一步完成。好处显而易见,更安全而且新的签名可缩短在设备上进行验证的时间(不需要费时地解压缩然后验证),从而加快应用安装速度。

解决方案一

v1和v2的签名使用

只勾选v1签名并不会影响什么,但是在7.0上不会使用更安全的验证方式

只勾选v2签名7.0以下会直接安装完显示未安装,7.0以上则使用了v2的方式验证

同时勾选v1和v2则所有机型都没问题

解决方案二

在app的build.gradle的android标签下加入如下

signingconfigs {
 debug {
  v1signingenabled true
  v2signingenabled true
 }
 release {
  v1signingenabled true
  v2signingenabled true
 }
}