java.io.IOException:无效的密钥库格式

有谁知道如何解决这个问题? 我尝试了很多东西,但没有一个能奏效。

当我点击更多细节时,我得到了这个:

at sun.security.provider.JavaKeyStore.engineLoad(Unknown Source) atsun.security.provider.JavaKeyStore$JKS.engineLoad(Unknown Source) at java.security.KeyStore.load(Unknown Source) at com.sun.deploy.security.RootCertStore$1.run(Unknown Source) at java.security.AccessController.doPrivileged(Native Method) at com.sun.deploy.security.RootCertStore.loadCertStore(Unknown Source) at com.sun.deploy.security.RootCertStore.load(Unknown Source) at com.sun.deploy.security.RootCertStore.load(Unknown Source) at com.sun.deploy.security.ImmutableCertStore.load(Unknown Source) at com.sun.deploy.security.TrustDecider.isAllPermissionGranted(Unknown Source) at com.sun.deploy.security.TrustDecider.isAllPermissionGranted(Unknown Source) at sun.plugin.security.PluginClassLoader.getPermissions(Unknown Source) at java.security.SecureClassLoader.getProtectionDomain(Unknown Source) at java.security.SecureClassLoader.defineClass(Unknown Source) at java.net.URLClassLoader.defineClass(Unknown Source) at java.net.URLClassLoader.access$000(Unknown Source) at java.net.URLClassLoader$1.run(Unknown Source) at java.security.AccessController.doPrivileged(Native Method) at java.net.URLClassLoader.findClass(Unknown Source) at sun.applet.AppletClassLoader.findClass(Unknown Source) at java.lang.ClassLoader.loadClass(Unknown Source) at sun.applet.AppletClassLoader.loadClass(Unknown Source) at java.lang.ClassLoader.loadClass(Unknown Source) at sun.applet.AppletClassLoader.loadCode(Unknown Source) at sun.applet.AppletPanel.createApplet(Unknown Source) at sun.plugin.AppletViewer.createApplet(Unknown Source) at sun.applet.AppletPanel.runLoader(Unknown Source) at sun.applet.AppletPanel.run(Unknown Source) at java.lang.Thread.run(Unknown Source) 

您可能会在复制/传输过程中损坏文件。

你在用maven吗? 如果要使用“filter = true”复制密钥库文件,则可能会损坏该文件。

请检查文件大小。

也许maven编码你的KeyStore,你可以设置filtering = false来解决问题。

  ...   ...  false ...    

(重新)安装最新的JDK(例如Oracle )为我修复了它。

在安装最新的JDK之前,当我在Terminal.app中执行以下命令时:

 keytool -list -keystore $(/usr/libexec/java_home)/jre/lib/security/cacerts -v 

结果是:

 keytool error: java.io.IOException: Invalid keystore format java.io.IOException: Invalid keystore format at sun.security.provider.JavaKeyStore.engineLoad(JavaKeyStore.java:650) at sun.security.provider.JavaKeyStore$JKS.engineLoad(JavaKeyStore.java:55) at java.security.KeyStore.load(KeyStore.java:1445) at sun.security.tools.keytool.Main.doCommands(Main.java:792) at sun.security.tools.keytool.Main.run(Main.java:340) at sun.security.tools.keytool.Main.main(Main.java:333) 

但是,在安装最新的Oracle JDK并重新启动终端后,执行以下命令:

 keytool -list -keystore $(/usr/libexec/java_home)/jre/lib/security/cacerts -v 

结果是:

 Enter keystore password: 

这表示路径上的keytool可以访问密钥库。

我认为您要使用的密钥库文件具有与Java版本不同或不受支持的格式。 你可以发布一些你的任务的更多信息吗?

通常,要解决此问题,您可能需要重新创建整个密钥库(例如,使用其他一些JDK版本)。 在导出 – 导入新旧密钥之间的密钥 – 如果您设法在其他地方打开旧密钥。

如果它只是一个不受支持的版本,请尝试使用BouncyCastle加密提供程序(尽管我不确定它是否为更多的密钥库类型添加了对Java的支持?)

编辑:我看了BC的function规格。

您的密钥库已损坏,您必须还原或重新生成它。

我在ubuntu上遇到了openJDK的问题,不得不安装Oracle JDK才能使它工作。

您可以在Google网站上按照此指南进行操作。