【问题标题】:KeyStore file "upgrade" java versionKeyStore 文件“升级”java 版本
【发布时间】:2017-08-07 14:49:02
【问题描述】:

是否可以更改 keytool 文件的 java 版本 - .keystore?我们用于签署 apks 的密钥库文件是在我们都知道的太旧的 java 7 下创建的。我们所有的应用程序都是在最新的 java 版本下开发的,但是由于签名过程,我们仍然需要在我们的机器上保留 java 7 仅用于签名。有什么方法可以在最新的 java 版本下复制整个密钥库?我已经尝试过,例如:

keytool -importkeystore -srckeystore old.keystore -destkeystore new.keystore -v

在 java 8 下出现异常:

无法初始化,java.io.IOException: DerInputStream.getLength(): 发现冗余长度字节

当我在 java 7 下运行相同的命令时,它当然可以工作。

已经尝试过:

Oleg 的帖子 - 给出了与上述相同的例外情况

无法初始化,java.io.IOException: DerInputStream.getLength(): 发现冗余长度字节

使用KeyStore Explorer 工具将原始密钥库导入新密钥库,该工具成功导入证书,但更改了SHA1指纹。

在 Java 7 下创建全新的密钥库文件并使用 Java 8 的密钥工具成功列出其详细信息,只是为了确认该密钥库文件以某种方式损坏。

即使尝试了 Oleg 的建议以在最新的 Java 下打开此密钥库文件仍然无法正常工作 Redundant length bytes exception

编辑 正如@Oleg 在评论中指出的那样,别名可能以某种方式被破坏了。因此,我们无法使用最新的 Java 进行签名。所以看起来我的问题没有解决方案。无论如何,将一个密钥库文件的内容复制到另一个是 Oleg 的解决方案是正确的。

【问题讨论】:

  • 我已经使用同一个密钥库大约 17 年了,如果不是更早的话,可以追溯到 Java 1.3,而且我从来没有遇到过兼容性问题。

标签: java android apk code-signing keytool


【解决方案1】:

Java 8 对 Java 7 创建的 keystore 文件应该没有问题。您可能有不同的默认密钥库类型,由 java.security 文件中的 keystore.type 属性或其他一些配置问题定义。见here

解决这个问题的简单方法是使用具有显式类型的临时keystore,而不是找出问题所在。

使用 Java 7 keytool:

keytool -importkeystore -srckeystore old.keystore -destkeystore temp.keystore.p12 -deststoretype PKCS12

然后是 Java 8:

keytool -importkeystore -srckeystore temp.keystore.p12 -srcstoretype PKCS12 -destkeystore new.keystore

【讨论】:

  • 还要确保两个版本的 JRE 都有 JCE 策略 jars
  • 感谢@Oleg,我之前找到了这个,但不确定这是否是我正在寻找的。会试一试,让你知道它是否有效。
  • 你需要的不止这些。这种方式会丢失所有的私钥。
  • @EJP 谢谢,你是完全正确的。我改变了答案。
  • @Mony 我改变了我的答案,现在检查它是否对你有帮助。
猜你喜欢
  • 2016-06-30
  • 1970-01-01
  • 1970-01-01
  • 2023-01-31
  • 2011-02-19
  • 2017-04-12
  • 2021-08-18
  • 2020-08-28
  • 2017-03-09
相关资源
最近更新 更多