android okhttp HttpURLConnection webSocket 设置不校验SSL证书

okhttp-----------------------在build的之前设置一下

我抽成一个静态的方法,传入对象调用即可

       
    public static void setSSLsocket(OkHttpClient.Builder okHttpClient) {
        //信任所有服务器地址
        okHttpClient.hostnameVerifier(new HostnameVerifier() {
            @Override
            public boolean verify(String s, SSLSession sslSession) {
                //设置为true
                return true;
            }
        });
        //创建管理器
        TrustManager[] trustAllCerts = new TrustManager[] { new X509TrustManager() {
            @Override
            public void checkClientTrusted(
                    java.security.cert.X509Certificate[] x509Certificates,
                    String s) throws java.security.cert.CertificateException {
            }

            @Override
            public void checkServerTrusted(
                    java.security.cert.X509Certificate[] x509Certificates,
                    String s) throws java.security.cert.CertificateException {
            }

            @Override
            public java.security.cert.X509Certificate[] getAcceptedIssuers() {
                return new java.security.cert.X509Certificate[] {};
            }
        } };
        try {
            SSLContext sslContext = SSLContext.getInstance("TLS");
            sslContext.init(null, trustAllCerts, new java.security.SecureRandom());
            //为OkHttpClient设置sslSocketFactory
            okHttpClient.sslSocketFactory(sslContext.getSocketFactory(), new X509TrustManager() {
                @Override
                public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
                    
                }

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

                }

                @Override
                public X509Certificate[] getAcceptedIssuers() {
                    return new X509Certificate[0];
                }
            });
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

webSocket------------------在conncet之前设置

调用上面的静态方法设置,将设置好的规则给socket

if (!"http://".equals(CommonUtils.getProtocol())) {
                //  加密协议-----设置信任所有证书
                OkHttpClient.Builder okHttpClient = new OkHttpClient.Builder();
                RxHelper.setSSLsocket(okHttpClient);
                OkHttpClient build = okHttpClient.build();
                mWebSocketClient.setSocket(build.sslSocketFactory().createSocket());
            }

HttpURLConnection


                        //获取对象
                        SSLContext context = SSLContext.getInstance("TLS");
                        //设置管理器
                        context.init(null, new TrustManager[]{new X509TrustManager() {
                            @Override
                            public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
                                
                            }

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

                            }

                            @Override
                            public X509Certificate[] getAcceptedIssuers() {
                                return new X509Certificate[0];
                            }
                        }}, null);
                        //设置管理器
                        HttpsURLConnection.setDefaultSSLSocketFactory(context.getSocketFactory());
                        HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier() {

                            @Override
                            public boolean verify(String arg0, SSLSession arg1) {
                                //返回true
                                return true;
                            }
                        });

//interUrl是URL对象,使用自的即可
                        cnt = (HttpsURLConnection) interUrl.openConnection();

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是Android使用OkHttp发送WebSocket请求的示例代码: ```java import okhttp3.OkHttpClient; import okhttp3.Request; import okhttp3.Response; import okhttp3.WebSocket; import okhttp3.WebSocketListener; import okio.ByteString; public class WebSocketClient extends WebSocketListener { private OkHttpClient client; private WebSocket webSocket; public WebSocketClient() { client = new OkHttpClient(); } public void start() { Request request = new Request.Builder().url("wss://your.websocket.url").build(); webSocket = client.newWebSocket(request, this); } @Override public void onOpen(WebSocket webSocket, Response response) { super.onOpen(webSocket, response); // 连接成功 webSocket.send("Hello, WebSocket!"); } @Override public void onMessage(WebSocket webSocket, String text) { super.onMessage(webSocket, text); // 收到消息 } @Override public void onMessage(WebSocket webSocket, ByteString bytes) { super.onMessage(webSocket, bytes); // 收到二进制消息 } @Override public void onClosing(WebSocket webSocket, int code, String reason) { super.onClosing(webSocket, code, reason); // 正在关闭连接 } @Override public void onClosed(WebSocket webSocket, int code, String reason) { super.onClosed(webSocket, code, reason); // 连接已关闭 } @Override public void onFailure(WebSocket webSocket, Throwable t, Response response) { super.onFailure(webSocket, t, response); // 连接失败 } } ``` 使用方法: ```java WebSocketClient client = new WebSocketClient(); client.start(); ``` 注意:需要在AndroidManifest.xml中添加网络权限: ```xml <uses-permission android:name="android.permission.INTERNET" /> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值