美文网首页
Android Studio2.3+打包apk后应用未安装

Android Studio2.3+打包apk后应用未安装

作者: Shawpoo的 | 来源:发表于2017-07-30 15:09 被阅读83次

    转载请注明出处:http://www.jianshu.com/p/691d8392643e
    本文出自Shawpoo的简书
    我的博客:CSDN博客

    前言

    Android 要求所有 APK 必须先使用证书进行数字签署,然后才能安装。当然这么做的原因是为了保证APK的唯一性,安全性。本文主要介绍在Android Studio2.3+打包apk后应用未安装的解决办法。

    Android Studio2.3+签名打包,应用未安装

    这几天在整项目的时候发现一个问题,通过Android Studio2.3+打包出来的apk,在android7.0+的手机上安装正常,但是在android7.0以下的均显示应用未安装,或者用PC工具都显示安装失败。

    在studio2.3版本以上打包会发现与之前的打包不一样了,下面多了一项Signature Versions的选择,如下图:

    签名打包.png

    经过打包实践会发现:

    • 如果只选V1,打包之后的apk在android7.0+或者7.0以下的手机安装均正常;

    • 如果只选V2,打包之后的apk在android7.0+的手机上安装正常,在android7.0以下的手机安装失败。

    • 如果同时勾选V1,V2,打包后的apk在android7.0+或者7.0以下的手机安装也都正常;

    APK signature scheme v2

    Android 7.0 引入一项新的应用签名方案 APK Signature Scheme v2,它能提供更快的应用安装时间和更多针对未授权 APK 文件更改的保护。在默认情况下,Android Studio 2.2 和 Android Plugin for Gradle 2.2 会使用 APK Signature Scheme v2 和传统签名方案来签署您的应用。

    虽然我们建议您对您的应用采用 APK Signature Scheme v2,但这项新方案并非强制性的。如果您的应用在使用 APK Signature Scheme v2 时不能正确开发,您可以停用这项新方案。禁用过程会导致 Android Studio 2.2 和 Android Plugin for Gradle 2.2 仅使用传统签名方案来签署您的应用。

    android {
        ...
        defaultConfig { ... }
        signingConfigs {
          release {
            storeFile file("myreleasekey.keystore")
            storePassword "password"
            keyAlias "MyReleaseKey"
            keyPassword "password"
            v2SigningEnabled false
          }
        }
      }
    
    

    所以要使用传统的方式签名的话,我们只需要在签名配置的release下添加:v2SigningEnabled false即可。或者个人建议打包时只选择V1。

    总结

    • 1、在开发的过程中遇到一些问题,多查阅官方API或文档。

    • 2、及时了解Android和Android Studio新版的特性,便于解决因版本不同带来的各种问题。

    • 3、多亲自实践,积累经验。

    参考阅读

    Android官网-签署您的应用
    官方介绍:APK signature scheme v2

    相关文章

      网友评论

          本文标题:Android Studio2.3+打包apk后应用未安装

          本文链接:https://www.haomeiwen.com/subject/nygsfxtx.html