在ubuntu 15.10和openjdk-8-jdk中是否缺少cacerts文件?

时间:2015-10-30 15:49:01

标签: ubuntu java-8 openjdk jsse ubuntu-15.10

我刚刚安装了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

3 个答案:

答案 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