我刚刚安装了Ubuntu 15.10和他们的openjdk-8-jdk(通过apt-get)。
现在我错过了cacerts文件。
通常位置有一个链接:
ls -l /usr/lib/jvm/java-8-openjdk-amd64/jre/lib/security/cacerts
lrwxrwxrwx 1 root root 27 Oct 22 01:47 /usr/lib/jvm/java-8-openjdk-amd64/jre/lib/security/cacerts -> /etc/ssl/certs/java/cacerts
但在/ etc / ssl / certs / java / cacerts中没有任何内容:
stat /etc/ssl/certs/java/cacerts
stat: cannot stat ‘/etc/ssl/certs/java/cacerts’: No such file or directory
答案 0 :(得分:33)
这是由于此处已报告的错误: Ubuntu bug ticket
上面的故障单链接了另一个类似的issue,它提供了一种解决方法:
$ sudo dpkg --purge --force-depends ca-certificates-java
$ sudo apt-get install ca-certificates-java
答案 1 :(得分:1)
如果您尝试使用ssl调用外部api并收到此错误,只需在此处添加一个Gergely答案已解决的错误:
java.lang.RuntimeException: Unexpected error: java.security.InvalidAlgorithmParameterException: the trustAnchors parameter must be non-empty
javax.net.ssl.SSLException: java.lang.RuntimeException: Unexpected error: java.security.InvalidAlgorithmParameterException: the trustAnchors parameter must be non-empty
at sun.security.ssl.Alerts.getSSLException(Alerts.java:208)
at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1946)
at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1903)
这解决了
$ sudo dpkg --purge --force-depends ca-certificates-java
$ sudo apt-get install ca-certificates-java
答案 2 :(得分:0)
在 centos 中你必须这样做:
$ sudo dnf install ca-certificates