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

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

Android Studio2.3+打包apk后应用未安装_第1张图片

前言

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

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

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

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

Android Studio2.3+打包apk后应用未安装_第2张图片
签名打包.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后应用未安装)