gpt4 book ai didi

java - HTTPS/SSL POST 方法在开发者机器上工作,但在服务器上不工作 - java

转载 作者:太空宇宙 更新时间:2023-11-03 13:21:25 26 4
gpt4 key购买 nike

大家好,我使用这段代码连接 https,它在我的电脑上工作正常,但是当我上传到我的服务器时,它不起作用

javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
at sun.security.ssl.Alerts.getSSLException(Alerts.java:192)
at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1964)
at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:328)
at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:322)
at sun.security.ssl.ClientHandshaker.serverCertificate(ClientHandshaker.java:1614)
at sun.security.ssl.ClientHandshaker.processMessage(ClientHandshaker.java:216)
at sun.security.ssl.Handshaker.processLoop(Handshaker.java:1052)
at sun.security.ssl.Handshaker.process_record(Handshaker.java:987)
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)
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 mehritco.ir.connection.URLConnection.read(URLConnection.java:38)
at mehritco.ir.cortexclient.objects.invoice.Price.setExchangeRate(Price.java:42)

而且这个日志文件不会在本地电脑上显示!

这里是我连接到 https/ssl 的代码

public String readLinkInJson(String url, String data) throws MalformedURLException, IOException {
URL obj = new URL(url);
System.out.println(data);
HttpsURLConnection con = (HttpsURLConnection) obj.openConnection();
con.setHostnameVerifier(hv);
con.setRequestMethod("POST");
con.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
con.setRequestProperty("User-Agent", "Mozilla/5.0");
con.setRequestProperty("Accept-Language", "en-US,en;q=0.5");
con.setDoOutput(true);
// For POST only - START
try (OutputStream os = con.getOutputStream()) {
os.write(data.getBytes("UTF-8"));
os.flush();
}
// For POST only - END
String inputLine;
StringBuilder response = new StringBuilder();
int responseCode = con.getResponseCode();
if(responseCode >= 400){
try (BufferedReader in = new BufferedReader(new InputStreamReader(con.getInputStream()))) {
while ((inputLine = in.readLine()) != null) {
response.append(inputLine);
}
}
}else{
try (BufferedReader in = new BufferedReader(new InputStreamReader(con.getErrorStream()))) {
while ((inputLine = in.readLine()) != null) {
response.append(inputLine);
}
}
}
return response.toString();

}

那我该怎么办呢?请帮我找到正确的代码...

最佳答案

我找到了答案!

 TrustManager[] trustAllCerts = new TrustManager[]{
new X509TrustManager() {
@Override
public java.security.cert.X509Certificate[] getAcceptedIssuers() {
return new X509Certificate[0];
}

@Override
public void checkClientTrusted(
java.security.cert.X509Certificate[] certs, String authType) {
}

@Override
public void checkServerTrusted(
java.security.cert.X509Certificate[] certs, String authType) {
}
}
};

try {
SSLContext sc = SSLContext.getInstance("SSL");
sc.init(null, trustAllCerts, new java.security.SecureRandom());
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
} catch (GeneralSecurityException e) {
}

在创建 url 对象之前添加此代码。

关于java - HTTPS/SSL POST 方法在开发者机器上工作,但在服务器上不工作 - java,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51398480/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com