javax.net.ssl.SSLHandshakeException: Connection closed by peer
时间: 2024-01-10 14:20:17 浏览: 722
javax.net.ssl.SSLHandshakeException: Connection closed by peer通常是由于SSL握手失败引起的。这可能是由于以下原因之一导致的:
1. 服务器不支持SSL协议版本或加密套件。
2. 客户端和服务器之间存在代理,代理可能会干扰SSL握手。
3. 证书问题,例如证书过期或不受信任。
解决此问题的方法包括:
1. 确保服务器支持客户端使用的SSL协议版本和加密套件。
2. 检查代理设置并尝试直接连接服务器。
3. 检查证书是否过期或不受信任,并确保证书链完整。
以下是一些可能有用的代码片段:
```java
// 禁用SSL验证
TrustManager[] trustAllCerts = new TrustManager[] { new X509TrustManager() {
public java.security.cert.X509Certificate[] getAcceptedIssuers() {
return null;
}
public void checkClientTrusted(X509Certificate[] certs, String authType) {
}
public void checkServerTrusted(X509Certificate[] certs, String authType) {
}
}};
SSLContext sc = SSLContext.getInstance("SSL");
sc.init(null, trustAllCerts, new java.security.SecureRandom());
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
// 设置代理
System.setProperty("https.proxyHost", "yourProxyServerHostname");
System.setProperty("https.proxyPort", "yourProxyServerPort");
// 打印证书信息
HttpsURLConnection conn = (HttpsURLConnection) url.openConnection();
conn.connect();
Certificate[] certs = conn.getServerCertificates();
for (Certificate cert : certs) {
System.out.println(cert);
}
```
阅读全文
相关推荐















