高高兴兴更新了2.3以后,搞了半天的时间,旧的项目都能跑了。以为就此爬坑完毕,哪知还是too yong,too森破了。
打包的时候又出现了问题,打出来的包在Android7.0上安装无问题。但是在Android7.0以下安装失败。
明明有签名的打包啊?一脸问号。然后去找Android的亲爹。
发现:
默认受信任的证书颁发机构
默认情况下,面向 Android 7.0 的应用仅信任系统提供的证书,且不再信任用户添加的证书颁发机构 (CA)。如果面向 Android N 的应用希望信任用户添加的 CA,则应使用网络安全性配置以指定信任用户 CA 的方式。
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 仅使用传统签名方案来签署您的应用。要仅用传统方案签署,打开模块级 build.gradle
文件,然后将行 v2SigningEnabled false
添加到您的版本签名配置中:
android { ... defaultConfig { ... } signingConfigs { release { storeFile file("myreleasekey.keystore") storePassword "password" keyAlias "MyReleaseKey" keyPassword "password" v2SigningEnabled false } } }
注意:如果您使用 APK Signature Scheme v2 签署您的应用,并对应用进行了进一步更改,则应用的签名将无效。出于这个原因,请在使用 APK Signature Scheme v2 签署您的应用之前、而非之后使用 zipalign
等工具。
如需了解详细信息,请阅读相关的 Android Studio 文档,这些文档介绍了如何在 Android Studio 中签署应用以及如何使用 Android Plugin for Gradle 为签署应用配置构建文件。
原文地址: https://developer.android.com/about/versions/nougat/android-7.0.html#scoped_directory_access
在Android Studio 2.2中,打包签名已经使用了两种方式: APK Signature Scheme v2 和传统签名方案来签署应用。但是在AS2.2中没有强调体现。在AS2.3中打包的时候有体现:
勾选V2就可能导致在Android7.0以下的设备无法安装。所以只要打包的时候勾选V1就好了。
问题解决,撒花。
假装有图.jpg