通过OKhttp3 访问 https地址

该代码段展示了如何在OkHttp3中设置信任所有证书,包括创建自定义的TrustManager和HostnameVerifier,以允许不受限制的SSL连接。此配置用于开发和测试环境,不应用于生产环境,因为这会忽略所有安全警告,可能导致敏感信息泄露。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/**
     * okHttp3添加信任所有证书
     *
     * @return
     */

    public static OkHttpClient getUnsafeOkHttpClient() {

        try {

            final TrustManager[] trustAllCerts = new TrustManager[]{

                    new X509TrustManager() {

                        @Override

                        public void checkClientTrusted(java.security.cert.X509Certificate[] chain, String authType) {

                        }

                        @Override

                        public void checkServerTrusted(java.security.cert.X509Certificate[] chain, String authType) {

                        }

                        @Override

                        public java.security.cert.X509Certificate[] getAcceptedIssuers() {

                            return new java.security.cert.X509Certificate[]{};

                        }

                    }

            };

            final SSLContext sslContext = SSLContext.getInstance("TLS");

            sslContext.init(null, trustAllCerts, new java.security.SecureRandom());

            final javax.net.ssl.SSLSocketFactory sslSocketFactory = sslContext.getSocketFactory();

            OkHttpClient.Builder builder = new OkHttpClient.Builder();

            //builder.sslSocketFactory(sslSocketFactory )方法已过时,使用下面方法替代

            builder.sslSocketFactory(sslSocketFactory, (X509TrustManager) trustAllCerts[0]);

            builder.hostnameVerifier(new HostnameVerifier() {

// 可以将不需要忽略的域名放入数组,也可为空(忽略所有证书)

                String[] arr = new String[]{};

                @Override

                public boolean verify(String hostname, SSLSession session) {

                    if (TextUtils.isEmpty(hostname)) {

                        return false;

                    }

                    return !Arrays.asList(arr).contains(hostname);

                }

            });

            return builder.build();

        } catch (Exception e) {

            throw new RuntimeException(e);

        }

    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

one 大白(●—●)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值