问题通常出现在Android 7.0及以上版本中。为了解决这个问题,需要确保您的服务器上具有有效的CA证书,并且使用使用LetsEncrypt等受信任的CA颁发机构签署的证书。如果您已经确认了您的证书是有效的,但您仍然无法连接到您的服务器,则可以尝试使用以下代码段来禁用SSL主机名验证:
// Create a trust manager that does not validate certificate chains
TrustManager[] trustAllCerts = new TrustManager[] {
new X509TrustManager() {
public X509Certificate[] getAcceptedIssuers() {
return new X509Certificate[0];
}
public void checkClientTrusted(X509Certificate[] certs, String authType) {
}
public void checkServerTrusted(X509Certificate[] certs, String authType) {
}
}
};
// Install the all-trusting trust manager
try {
SSLContext sc = SSLContext.getInstance("TLS");
sc.init(null, trustAllCerts, new SecureRandom());
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
} catch (Exception e) {
e.printStackTrace();
}
请注意,这个解决方法虽然能帮助您连接到服务器,但它会牺牲SSL的安全性。因此,我们建议您在最终上线之前正式的解决该问题。