我刚接触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打网络服务器,我没有得到任何类型的错误。我是我错过了某种配置?任何帮助将不胜感激。谢谢!
8条答案
按热度按时间ljsrvy3e1#
如果你不能修复无论如何.如果你是在防火墙内.
那好吧。
你可能不能下载https.
应修复编辑www.example.com文件。gradle-wrapper.properties file.
从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
g0czyy6m2#
我也遇到过同样的问题,但是我的症状是Ubuntu机器无法解析任何SSL主机,除非我专门将它们添加到Java的证书颁发机构(cacert)文件中。
我偶然发现了这个Debian bug,并找到了一个相当直接的解决方案:删除
ca-certificates-java
并重新安装:我做了一个
./gradlew clean
,一切都恢复了生机。ws51t4hk3#
Gradle站点的证书似乎被弄乱了。执行
gradlew clean
应该可以修复此问题。请参见Gradle论坛上的此主题:http://discuss.gradle.org/t/urgent-ssl-apache-configuration-for-services-gradle-org-is-bad/8808/4lfapxunr4#
步骤:
1.运行
gradlew -Djavax.net.debug=all tasks
1.仔细检查调试日志,看看是否发现任何异常。
在我的例子中,看到像
Zscaler
这样的东西就成功了,因为我知道我打开了Zscaler
(顺便说一句,它重写了TLS流量blablabla),它试图找到 * 到请求的目标的有效证书路径 *,显然它找不到。2选项:
1.退出
Zscaler
1.如果无法退出
Zscaler
,请转到浏览器,exportZscaler Root Certificate
并将其导入
gradle
正在使用的JVM信任库中,类似于:keytool-导入-信任cacerts-别名Zscaler-文件"Zscaler根CA. cer"-密钥库" %JAVA_HOME %"\jre\lib\安全\cacerts
gradlew clean
。lymnna715#
在我的例子中,这个问题是由一个过时的(7年前的)Java版本引起的。甚至
gradlew clean
也失败了。在Java更新后,它工作得很好。oxf4rvwz6#
在我的例子中,我在公司网络上,在代理后面,据我所知,它重写SSL证书,使Java安装不信任其中任何一个证书。
为了解决这个问题,我必须gradle.properties在主目录的.gradle(
~/.gradle/gradle.properties
)下创建一个www.example.com文件,并添加以下行: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
mznpcxlj7#
这是因为,Gradle会尝试在您的本地计算机中查找已安装的软件包。如果您有安装位置:
D:\应用程序\分级-3.3
在eclipse中执行以下步骤:
1.新建项目
1.输入项目名称
1.本地安装目录
1.单击完成。
你可以走了。
hts6caw38#
在用户主页中创建此配置文件:
x一个月一次x一个月一次x一个月二次x一个月三次