OkHttp Https 证书忽略

本文介绍如何通过实现X509TrustManager接口并覆盖其方法来信任所有SSL证书,适用于需要绕过证书验证的场景。同时展示了如何在OkHttpClient中配置自定义的SSLSocketFactory和HostnameVerifier。

1、实现X509TrustManager 接口

public class TrustAllCerts implements X509TrustManager {
   
   
    @Override
    public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
   
   
    }

    @Override
    public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
   
   

        if (chain == null) {
   
   
            
### OkHttp 调用 HTTPS 忽略 SSL 证书实现方法 为了使 OkHttp 客户端能够忽略 SSL 证书,在发起 HTTPS 请求时可以自定义 `SSLSocketFactory` 和 `HostnameVerifier` 来绕过默认的安全检查。 创建一个不验证任何主机名的 `HostnameVerifier`: ```java final HostnameVerifier hostnameVerifier = (hostname, session) -> true; ``` 构建允许所有证书的信任管理器列表,这通常意味着接受所有的服务器证书而不做额外校验: ```java import javax.net.ssl.TrustManager; import javax.net.ssl.X509TrustManager; // 创建信任所有证书的信任管理器 final TrustManager[] trustAllCerts = new TrustManager[]{ new X509TrustManager() { public java.security.cert.X509Certificate[] getAcceptedIssuers() {return null;} public void checkClientTrusted(java.security.cert.X509Certificate[] chain, String authType) {} public void checkServerTrusted(java.security.cert.X509Certificate[] chain, String authType) {} } }; ``` 初始化并配置 `SSLContext` 使用上述信任管理器来跳过标准的 SSL 握手过程中的身份验证步骤[^1]: ```java try { final SSLContext sslContext = SSLContext.getInstance("TLS"); sslContext.init(null, trustAllCerts, new java.security.SecureRandom()); // 设置 OkHttpClient 使用定制化的 SSLSocketFactory 和 HostnameVerifier OkHttpClient client = new OkHttpClient.Builder() .sslSocketFactory(sslContext.getSocketFactory(), (X509TrustManager)trustAllCerts[0]) .hostnameVerifier(hostnameVerifier) .build(); } catch (Exception e) { throw new RuntimeException(e); } ``` 需要注意的是,这种方法虽然解决了特定场景下的开发调试需求,但在生产环境中部署此类代码存在严重的安全隐患。因为这样做会使得应用程序容易受到中间人攻击(Man-in-the-Middle Attack),从而危及通信数据的安全性和隐私保护[^2]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值