Https 连接 Android:忽略网络请求的服务器证书
在 Android 中建立 HTTPS 连接时,考虑服务器证书安全至关重要。但是,在某些情况下,可能需要在不验证服务器证书的情况下建立连接。本文介绍了如何在 Android 中绕过 HTTP 连接的服务器证书验证。
解决方案:信任所有服务器
要忽略服务器证书并信任所有连接,您可以实现自定义 HostnameVerifier 并安装验证所有证书的信任管理器。代码如下:
HostnameVerifier DO_NOT_VERIFY = new HostnameVerifier() { public boolean verify(String hostname, SSLSession session) { return true; } }; private static void trustAllHosts() { TrustManager[] trustAllCerts = new TrustManager[] { new X509TrustManager() { public java.security.cert.X509Certificate[] getAcceptedIssuers() { return new java.security.cert.X509Certificate[] {}; } public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {} public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {} } }; SSLContext sc = SSLContext.getInstance("TLS"); sc.init(null, trustAllCerts, new java.security.SecureRandom()); HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory()); }
连接建立
实现信任所有主机方法后,您可以使用以下代码建立 HTTP 连接,同时忽略证书验证:
HttpURLConnection http = null; if (url.getProtocol().toLowerCase().equals("https")) { trustAllHosts(); HttpsURLConnection https = (HttpsURLConnection) url.openConnection(); https.setHostnameVerifier(DO_NOT_VERIFY); http = https; } else { http = (HttpURLConnection) url.openConnection(); }
这将允许您在不依赖服务器证书验证的情况下建立 HTTPS 连接,这可能会导致在特定场景下是必要的。需要注意的是,这种方法只能用于安全性不是主要问题的开发或受控环境。
以上是Android中如何绕过HTTPS服务器证书验证?的详细内容。更多信息请关注PHP中文网其他相关文章!