【发布时间】:2020-05-27 02:19:28
【问题描述】:
我正在尝试使用
向“https://api.ecs.echa.europa.eu”发送一个HttpRequestHttpRequest request = HttpRequest.newBuilder()
.uri(URI.create("https://api.ecs.echa.europa.eu"))
.GET()
.build();
HttpClient httpClient = HttpClient.newBuilder().version(HttpClient.Version.HTTP_1_1).build();
HttpResponse<String> response = httpClient.send(request, HttpResponse.BodyHandlers.ofString());
执行此代码我得到javax.net.ssl.SSLHandshakeException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
现在我已经通过将证书添加到$JAVA_HOME/jre/lib/security/cacerts 下的 java 信任库中找到了解决此问题的方法
我仍然不明白,为什么这是必要的:
特定网站 (https://api.ecs.echa.europa.eu) 使用根证书DigiCert Global Root CA,该证书已包含在 java 信任库中。为什么这还不够?
向使用此根证书的其他网站发送请求确实有效...
感谢您的帮助:)
【问题讨论】:
-
Java 的哪个版本?
-
如果您使用的是应用程序容器,那么添加到 $JAVA_HOME/jre/lib/security/cacerts 将无济于事。您必须将其添加到应用容器正在使用的证书中。
-
我使用的是 Java 13.0.1。添加到 cacerts 确实有帮助,但我想知道为什么它是必要的
标签: java ssl sslhandshakeexception truststore root-certificate