Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES: ... has no certificates at entry AndroidManifest.xml]

        很长一段时间都用快速打包(packer-ng-plugin),没注意到底用Android Studio打包会有什么区别,今天写了个demo,居然发现我输入了签名之后只有一次是安装成功的,后边都是安装报错:Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES: Package /data/app/vmdl924957567.tmp/base.apk has no certificates at entry AndroidManifest.xml]

       分析查找问题原因:

              可能的原因:手机版本问题?google后发现签名确实存在两个版本,Android7.0中引入了APK Signature Scheme v2,v1呢是jar Signature来自JDK。我使用的是Android studio3.1,也是查询才知道有这两个版本的区分,老的版本应该没有,也没太注意到这个改动,毕竟不是每天都需要签名打包,而且配置好了之后就不需要动了,所以察觉不到。

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

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

                 v1和v2的签名使用

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

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

同时勾选V1和V2则所有机型都没问题

               但是我确实勾选了两个选项,而且试过了不同的勾选组合,都不选(会提示你最少选一个),选一个,选两个,都是报相同的错误,说基础apk没有签名。

               找了Stack Overflow有人有相同的问题,但是也只是简单的说勾选两个后就解决了。过了好久,一天,难受,堵得慌,干其他事去。。。

               且换了台手机还是一样报错。换了个demo工程,换了个keystore还是同样报错!!!

               晚上回到电脑前,不经意间发现新的demo工程中有截图中的区别习惯了在build-out-apk-release文件夹中找签好名的包,但是这个使用安装是不成功的。而且从名字也可以看出来是app-release-unsigned.apk,但是在下边多了一个release文件夹,这里边的文件安装就是正常的。

               于是我把这个文件删除了,再直接用1,命令行打正式包;或者2,用Android studio打正式包,这个文件夹都未出现。好奇怪!!!我之前输入过秘钥的各种密码别名啊!!!为什么出不来正常的包?我之前有一次打正式包安装是正常的啊!!!

                不经意间又点击输入签名信息的步骤,!!!需要你再次输入秘钥信息!!!输入完之后再次用Android studio的按键打包,还是命令打包,都会出来这个文件夹。主工程中一级文件夹release,这里边的签名文件就是正常的app-release.apk。安装一切正常。一直报错的是app-release-unsigned.apk,未签名当然会报错。

                 所以最后总结一下,解决办法就是:你再输入一次签名秘钥,打正式包,就会生成主工程下的一级文件夹release,这里边的app-release.apk就是签名正常的。而同时生成的build-out-apk-release-(app-release-unsigned.apk)是不会安装成功的,这个包签名不完全。为什么会这样还不清楚。希望能帮助解决你遇到的相同的问题。

 

猜你喜欢

转载自blog.csdn.net/Goals1989/article/details/82320295