Signature Versions V1&V2

原文地址:https://blog.csdn.net/xmxkf/article/details/71123973


 最近更新了一下Android Studio ,今天打正式包的时候发现需要选择签名版本:

Signature Versions V1&V2_第1张图片 
  由于急着打包,也没多想就一路下一步了,结果在某些测试机上一直都安装失败,经过一番研究发现与签名版本有关系。

V1和V2的区别

Android 7.0中引入了APK Signature Scheme V2(Full APK Signature),而V1(jar Signature) 来自JDK;

V1:仅验证未解压的文件内容,这样APK 签署后可进行许多修改 ,可以移动甚至重新压缩文件;

V2:验证压缩文件的所有字节,而不是单个 ZIP 条目,因此,在签名后无法再更改(包括 zipalign)。正因如此,现在在编译过程中,我们将压缩、调整和签署合并成一步完成。好处显而易见,更安全而且新的签名可缩短在设备上进行验证的时间(不需要费时地解压缩然后验证),从而加快应用安装速度。如有任何自定义任务篡改 APK 文件或对其进行后处理(无论以任何方式),那么V2 签名会有作废的风险,从而导致您的 APK 与 Android 7.0 及更高版本不兼容。

V1和V2的签名使用

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

  为了避免打包时忘记将他们都勾选上而造成的上面的错误,可以在app的build.gradle的android标签下加入如下配置,打包时就可以一路next了,默认帮我们勾选上。

signingConfigs {
        debug {
            v1SigningEnabled true
            v2SigningEnabled true
        }
        release {
            v1SigningEnabled true
            v2SigningEnabled true
        }
    }

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