27

我是 Gradle 新手,正在阅读这里的 Spring 教程:

http://spring.io/guides/gs/gradle/

我到了它告诉我添加此任务的部分:

task wrapper(type: Wrapper) {
     gradleVersion = '2.3'
}

我运行 gradle wrapper 来创建 gradlew 和 gradlew.bat 文件。

尝试运行这两个我得到这个异常:

Downloading https://services.gradle.org/distributions/gradle-2.3-bin.zip

Exception in thread "main" javax.net.ssl.SSLHandshakeException: sun.security.val
idator.ValidatorException: PKIX path building failed: sun.security.provider.cert
path.SunCertPathBuilderException: unable to find valid certification path to req
uested target
        at sun.security.ssl.Alerts.getSSLException(Alerts.java:192)
        at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1884)
        at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:276)
        at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:270)
        at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.
java:1341)
        at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.jav
a:153)
        at sun.security.ssl.Handshaker.processLoop(Handshaker.java:868)
        at sun.security.ssl.Handshaker.process_record(Handshaker.java:804)
        at sun.security.ssl.SSLSocketImpl.readRecord(SSLSocketImpl.java:1016)
        at sun.security.ssl.SSLSocketImpl.performInitialHandshake(SSLSocketImpl.
java:1312)
        at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1339
)
        at sun.security.ssl.SSLSocketImpl.startHandshake(SSLSocketImpl.java:1323
)
        at sun.net.www.protocol.https.HttpsClient.afterConnect(HttpsClient.java:
563)
        at sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect
(AbstractDelegateHttpsURLConnection.java:185)
        at sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLCon
nection.java:1300)
        at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(Http
sURLConnectionImpl.java:254)
        at org.gradle.wrapper.Download.downloadInternal(Download.java:56)
        at org.gradle.wrapper.Download.download(Download.java:42)
        at org.gradle.wrapper.Install$1.call(Install.java:57)
        at org.gradle.wrapper.Install$1.call(Install.java:44)
        at org.gradle.wrapper.ExclusiveFileAccessManager.access(ExclusiveFileAcc
essManager.java:65)
        at org.gradle.wrapper.Install.createDist(Install.java:44)
        at org.gradle.wrapper.WrapperExecutor.execute(WrapperExecutor.java:126)
        at org.gradle.wrapper.GradleWrapperMain.main(GradleWrapperMain.java:56)
Caused by: sun.security.validator.ValidatorException: PKIX path building failed:
 sun.security.provider.certpath.SunCertPathBuilderException: unable to find vali
d certification path to requested target
        at sun.security.validator.PKIXValidator.doBuild(PKIXValidator.java:385)
        at sun.security.validator.PKIXValidator.engineValidate(PKIXValidator.jav
a:292)
        at sun.security.validator.Validator.validate(Validator.java:260)
        at sun.security.ssl.X509TrustManagerImpl.validate(X509TrustManagerImpl.j
ava:326)
        at sun.security.ssl.X509TrustManagerImpl.checkTrusted(X509TrustManagerIm
pl.java:231)
        at sun.security.ssl.X509TrustManagerImpl.checkServerTrusted(X509TrustMan
agerImpl.java:126)
        at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.
java:1323)
        ... 19 more
Caused by: sun.security.provider.certpath.SunCertPathBuilderException: unable to
 find valid certification path to requested target
        at sun.security.provider.certpath.SunCertPathBuilder.engineBuild(SunCert
PathBuilder.java:196)
        at java.security.cert.CertPathBuilder.build(CertPathBuilder.java:268)
        at sun.security.validator.PKIXValidator.doBuild(PKIXValidator.java:380)
        ... 25 more

我尝试在https://services.gradle.org/distributions/gradle-2.3-bin.zip访问网络服务器,但没有收到任何错误。我错过了某种配置?任何帮助,将不胜感激。谢谢!

4

8 回答 8

44

如果你无论如何都无法修复。如果你在防火墙内。
然后。
你可能无法下载https。

应该修复编辑 gradle-wrapper.properties 文件。

vi [project]/gradle/wrapper/gradle-wrapper.properties

#distributionUrl=https\://services.gradle.org/distributions/gradle-2.8-bin.zip 
distributionUrl=http\://services.gradle.org/distributions/gradle-2.8-bin.zip

从 https 更改为 http...

http://blog.cjred.net/gradlew-bat-and-gradlew-sslhandshakeexception/

我修改后,它说:服务器返回 HTTP 响应代码:403 用于 URL:http ://services.gradle.org/distributions/gradle-6.0.1-all.zip

于 2015-11-13T06:49:44.247 回答
20

我遇到了同样的问题,但是我的症状是我的 Ubuntu 机器无法解析任何 SSL 主机,除非我专门将它们添加到 Java 的证书颁发机构 (cacert) 文件中。

我偶然发现了这个 Debian 错误,并找到了一个相当直接的解决方案:删除ca-certificates-java并重新安装它:

sudo dpkg --purge --force-depends ca-certificates-java
sudo apt-get install ca-certificates-java

我做了一个./gradlew clean很好的措施,一切都恢复了生机。

于 2015-06-18T20:10:35.183 回答
2

看来,gradle 站点的证书搞砸了。做一个gradlew clean应该解决这个问题。请参阅 Gradle 论坛上的此主题:http: //discuss.gradle.org/t/urgent-ssl-apache-configuration-for-services-gradle-org-is-bad/8808/4

于 2015-04-12T05:48:53.250 回答
1

就我而言,问题是由 Java 的过时(7 岁)版本引起的。甚至gradlew clean失败了。Java更新后它工作正常。

于 2015-10-09T12:53:41.383 回答
1

在我的情况下,我在公司网络和代理后面,据我了解,它会重写 SSL 证书,使 Java 安装不信任其中的任何一个。

为了解决这个问题,我必须在我的主目录中的 .gradle ( ~/.gradle/gradle.properties) 下创建一个 gradle.properties 文件并添加以下行:

org.gradle.jvmargs=-DsystemProp.https.proxyHost=<myProxyHost> -DsystemProp.https.proxyPort=<myProxyPort> -DsystemProp.https.proxyUser=<myProxyUsername> -DsystemProp.https.proxyPassword=<myProxyPassword>

该解决方案基于此 SO 答案:Gradle use certificate authentication for repository

于 2018-06-27T10:39:33.087 回答
0

脚步:

  1. gradlew -Djavax.net.debug=all tasks
  2. 浏览调试日志,看看是否发现任何异常。

就我而言,看到类似Zscaler的东西就可以了,因为我知道我有Zscaler(顺便重写了 TLS 流量blablabla),它试图找到请求目标的有效认证路径,显然它找不到.

2个选项:

  1. 出口Zscaler

  2. 如果退出Zscaler不是一个选项,请转到您的浏览器,将其导出 Zscaler Root Certificate并导入到gradle正在使用的 JVM 信任库中,例如:

    keytool -import -trustcacerts -alias Zscaler -file "Zscaler Root CA.cer" -keystore "%JAVA_HOME%"\jre\lib\security\cacerts

重要提示gradlew clean在重试任何命令之前执行一次。

于 2021-08-23T06:39:29.430 回答
-1

这是因为,Gradle 会尝试在您的本地计算机中查找已安装的包。如果您有安装位置:

D:\apps\gradle-3.3

在 Eclipse 中按照以下步骤操作:

  1. 新项目
  2. 摇篮项目
  3. 输入项目名称
  4. 本地安装目录
  5. 单击完成。

你已准备好出发。

于 2017-02-16T21:16:07.493 回答
-3

在用户主页中创建此配置文件:

$ vi ~/.yarnrc # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. # yarn lockfile v1 strict-ssl false

于 2018-11-27T10:56:12.140 回答