Heim >Java >javaLernprogramm >Wie gehe ich mit ungültigen SSL-Zertifikaten in Apache HttpClient ohne KeyManager und TrustManager um?
Umgang mit ungültigen SSL-Zertifikaten mit Apache HttpClient
Frage:
Bei Verwendung von Apache HttpClient Beim Aufbau einer HTTPS-Verbindung treten Fehler im Zusammenhang mit ungültigen SSL-Zertifikaten auf. Wie kann ich diese Fehler beheben und gleichzeitig die Verwendung von KeyManager und TrustManager vermeiden?
Antwort:
Der Umgang mit ungültigen SSL-Zertifikaten in Apache HttpClient erfordert einen der folgenden Ansätze:
Implementieren eines TrustManagers für jedes Zertifikat:
Der folgende Code zeigt, wie ein SSLContext mit einem TrustManager erstellt wird, der jedes Zertifikat akzeptiert:
<code class="java">import java.net.URL; import java.security.SecureRandom; import java.security.cert.CertificateException; import java.security.cert.X509Certificate; import javax.net.ssl.HostnameVerifier; import javax.net.ssl.HttpsURLConnection; import javax.net.ssl.KeyManager; import javax.net.ssl.SSLContext; import javax.net.ssl.SSLSession; import javax.net.ssl.TrustManager; import javax.net.ssl.X509TrustManager; public class SSLTest { public static void main(String [] args) throws Exception { // configure the SSLContext with a TrustManager SSLContext ctx = SSLContext.getInstance("TLS"); ctx.init(new KeyManager[0], new TrustManager[] {new DefaultTrustManager()}, new SecureRandom()); SSLContext.setDefault(ctx); URL url = new URL("https://mms.nw.ru"); HttpsURLConnection conn = (HttpsURLConnection) url.openConnection(); conn.setHostnameVerifier(new HostnameVerifier() { @Override public boolean verify(String arg0, SSLSession arg1) { return true; } }); System.out.println(conn.getResponseCode()); conn.disconnect(); } private static class DefaultTrustManager implements X509TrustManager { @Override public void checkClientTrusted(X509Certificate[] arg0, String arg1) throws CertificateException {} @Override public void checkServerTrusted(X509Certificate[] arg0, String arg1) throws CertificateException {} @Override public X509Certificate[] getAcceptedIssuers() { return null; } } }</code>
Das obige ist der detaillierte Inhalt vonWie gehe ich mit ungültigen SSL-Zertifikaten in Apache HttpClient ohne KeyManager und TrustManager um?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!