Erro de certificado do Ubuntu 17.10 Java 8

10

Eu tenho uma nova instalação do Ubuntu 17.10, na qual instalei o pacote oracle-java8-installer (da PPA).

Mas quando tento compilar um projeto iônico usando "ionic cordova build android", ele lança este erro:

    Exception in thread "main" 
    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:1959)
        at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1916)
        at sun.security.ssl.SSLSocketImpl.handleException(SSLSocketImpl.java:1899)
        at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1420)
        at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1397)
        at sun.net.www.protocol.https.HttpsClient.afterConnect(HttpsClient.java:559)
        at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:185)
        at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1564)
        at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1492)
        at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(HttpsURLConnectionImpl.java:263)
        at org.gradle.wrapper.Download.downloadInternal(Download.java:60)
        at org.gradle.wrapper.Download.download(Download.java:45)
        at org.gradle.wrapper.Install$1.call(Install.java:62)
        at org.gradle.wrapper.Install$1.call(Install.java:48)
        at org.gradle.wrapper.ExclusiveFileAccessManager.access(ExclusiveFileAccessManager.java:69)
        at org.gradle.wrapper.Install.createDist(Install.java:48)
        at org.gradle.wrapper.WrapperExecutor.execute(WrapperExecutor.java:107)
        at org.gradle.wrapper.GradleWrapperMain.main(GradleWrapperMain.java:61)
    Caused by: java.lang.RuntimeException: Unexpected error: java.security.InvalidAlgorithmParameterException: the trustAnchors parameter must be non-empty
        at sun.security.validator.PKIXValidator.<init>(PKIXValidator.java:91)
        at sun.security.validator.Validator.getInstance(Validator.java:179)
        at sun.security.ssl.X509TrustManagerImpl.getValidator(X509TrustManagerImpl.java:312)
        at sun.security.ssl.X509TrustManagerImpl.checkTrustedInit(X509TrustManagerImpl.java:171)
        at sun.security.ssl.X509TrustManagerImpl.checkTrusted(X509TrustManagerImpl.java:184)
        at sun.security.ssl.X509TrustManagerImpl.checkServerTrusted(X509TrustManagerImpl.java:124)
        at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1496)
        at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:216)
        at sun.security.ssl.Handshaker.processLoop(Handshaker.java:1026)
        at sun.security.ssl.Handshaker.process_record(Handshaker.java:961)
        at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:1072)
        at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.java:1385)
        at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1413)
        ... 14 more
    Caused by: java.security.InvalidAlgorithmParameterException: the trustAnchors parameter must be non-empty
        at java.security.cert.PKIXParameters.setTrustAnchors(PKIXParameters.java:200)
        at java.security.cert.PKIXParameters.<init>(PKIXParameters.java:120)
        at java.security.cert.PKIXBuilderParameters.<init>
    (PKIXBuilderParameters.java:104)
        at sun.security.validator.PKIXValidator.<init>(PKIXValidator.java:89)
        ... 26 more

Estou conectado à internet e tentei:

$ sudo update-ca-certificates -f
$ sudo apt install --reinstall ca-certificates-java

... e também reinstale o npm, ionic, java e gradle, tudo sem sucesso.

editar: Eu também tenho ANDROID_HOME e JAVA_HOME exportados em .bashrc e Android Studio instalado. Eu tentei construir o projeto em uma máquina diferente e funciona bem. Não posso tentar usar o OpenJDK porque não funciona bem com o Android Studio.

Leonardo Amorim
fonte

Respostas:

26

Experimentar

sudo dpkg --purge --force-depends ca-certificates-java

Seguido por

sudo apt-get install ca-certificates-java

consertar cacerts quebrados.
Para mim, isso corrigiu.
Boa sorte!

Zod
fonte
Trabalhou para mim também para o openjdk-9! Alguma explicação sobre por que isso funciona quando --reinstalle manualmente executando o script pós-instalação não? Estou muito interessado em referência futura. Obrigado!
Andy
1
AMD. Eu tenho procurado por esta resposta por semanas. Todas as outras respostas a essa pergunta que encontrei não fizeram nada - absolutamente nada. Isso funcionou perfeitamente. Algo parece bastante quebrado com essas certs no Ubuntu 17.10.
Dan
Corrigido o Jenkins em 17.10 também. Obrigado (e votado)
Forbesmyester
Muito obrigado trabalhou para mim com o gradle (4.5.1) e o open-jdk-9. Não funcionou com o oracle-jdk-9.
Pabi
Solução para Ubuntu 18.04. Instalei o openjdk versão 11. Por causa do Android, tive que instalar adicionalmente o openjdk 8. Por motivos desconhecidos, o arquivo cacerts instalado pelo openjdk 11 não funciona com o openjdk 8. Tive que desinstalar os dois jdks e instalar apenas a versão 8 e, em seguida, regenerar os cacerts Arquivo.
Greg Dan