【问题标题】:INSTALL_PARSE_FAILED_NO_CERTIFICATES from adb install; using Java 6, Android 5.0.2来自 adb install 的 INSTALL_PARSE_FAILED_NO_CERTIFICATES ;使用 Java 6、Android 5.0.2
【发布时间】:2016-05-04 18:18:31
【问题描述】:

我已按照此处和其他地方的说明创建签名的 jar 文件,当我尝试将签名的 .apk 安装到我的 LG-D415 上时,我仍然收到 INSTALL_PARSE_FAILED_NO_CERTIFICATES。 如前所述,签名算法似乎更适用于 Java 6。因此,我卸载了除此之外的所有 Java 版本,并确保 keytool 和 jarsigner 使用的是 Java 6。

keytool -genkey -v -keystore debug.keystore -alias TabletClient -keyalg RSA -keysize 2048 -validity 20000
jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore debug.keystore Release\TabletClient.apk TabletClient
zipalign -v 4 Release\TabletClient.apk Release\TabletClientZ.apk
adb install Release\TabletClientZ.apk

adb logcat 显示:

W/PackageManager(  957): android.content.pm.PackageParser$PackageParserException: Failed to collect certificates from /data/app/vmdl272628750.tmp/base.apk
W/PackageManager(  957):        at android.content.pm.PackageParser.collectCertificates(PackageParser.java:1108)
W/PackageManager(  957):        at android.content.pm.PackageParser.collectCertificates(PackageParser.java:1035)
W/PackageManager(  957):        at com.android.server.pm.PackageManagerService.installPackageLI(PackageManagerService.java:11848)
W/PackageManager(  957):        at com.android.server.pm.PackageManagerService.access$2500(PackageManagerService.java:273)
W/PackageManager(  957):        at com.android.server.pm.PackageManagerService$7.run(PackageManagerService.java:9770)
W/PackageManager(  957):        at android.os.Handler.handleCallback(Handler.java:739)
W/PackageManager(  957):        at android.os.Handler.dispatchMessage(Handler.java:95)
W/PackageManager(  957):        at android.os.Looper.loop(Looper.java:135)
W/PackageManager(  957):        at android.os.HandlerThread.run(HandlerThread.java:61)
W/PackageManager(  957):        at com.android.server.ServiceThread.run(ServiceThread.java:46)
W/PackageManager(  957): Caused by: java.lang.SecurityException: Can not recognize a critical extension
W/PackageManager(  957):        at org.apache.harmony.security.utils.JarUtils.verifySignature(JarUtils.java:120)
W/PackageManager(  957):        at java.util.jar.JarVerifier.verifyCertificate(JarVerifier.java:346)
W/PackageManager(  957):        at java.util.jar.JarVerifier.readCertificates(JarVerifier.java:320)
W/PackageManager(  957):        at java.util.jar.StrictJarFile.<init>(StrictJarFile.java:68)
W/PackageManager(  957):        at android.content.pm.PackageParser.collectCertificates(PackageParser.java:1050)

有什么想法吗?任何帮助将不胜感激。

【问题讨论】:

    标签: java android installation adb sign


    【解决方案1】:

    我找到了答案。 .apk 是作为 adt 构建的一部分进行签名的,但使用的密钥不起作用。由于某种原因,jarsigner 步骤没有完全替换旧签名,或者显示任何错误。因此,当 .apk 安装在 Android 设备上时,它遇到了坏密钥的问题。 找到这个的诀窍是在运行 jarsigner 之前将 .apk 文件作为 zip 文件打开,然后删除 META-INF 目录。 jarsigner 然后正确地创建了它,并使用 Android 在 .android 目录中创建的密钥。 一旦我意识到这一点,我就可以通过将 adt 命令更改为使用 Android 的密钥来解决问题。

    【讨论】:

    • 您能粘贴最终解决问题的 adt 命令吗?
    • 没关系,我的解决方案是将 signingConfig signingConfigs.release 添加到我的wear gradle release buildType。
    猜你喜欢
    • 1970-01-01
    • 2020-04-14
    • 2016-07-25
    • 2012-04-06
    • 2023-04-06
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-02-14
    相关资源
    最近更新 更多