Вам необходимо использовать sslSocketFactory(SSLSocketFactory sslSocketFactory, X509TrustManager trustManager)
, который не считается устаревшим.
Используйте эту переменную (которая создает диспетчер доверия, который не проверяет цепочки сертификатов):
TrustManager[] trustAllCerts = new TrustManager[] {
new X509TrustManager() {
@Override
public void checkClientTrusted(java.security.cert.X509Certificate[] chain, String authType) throws CertificateException {
}
@Override
public void checkServerTrusted(java.security.cert.X509Certificate[] chain, String authType) throws CertificateException {
}
@Override
public java.security.cert.X509Certificate[] getAcceptedIssuers() {
return new java.security.cert.X509Certificate[]{};
}
}
};
и перейдите кsslSocketFactory()
следующим образом:
builder.sslSocketFactory(sslSocketFactory, (X509TrustManager)trustAllCerts[0]);
также примените это для проверки каждого хоста:
builder.hostnameVerifier(new HostnameVerifier() {
@Override
public boolean verify(String hostname, SSLSession session) {
return true;
}
});