哥哥手把手教你使用OKHttp3进行WebSocket长连接,忽略证书,完善SSL-HandShake问题

步骤一:

注意,okhttp是3.5以后才添加对WebSocket的支持,以前都是提供了扩展库okhttp-ws,建议使用3.5以上版本。

在项目中添加

implementation   'com.squareup.okhttp3:okhttp:3.8.1'

步骤二:

创建一个内部类,集成okhttp中抽象类WebSocketListener 

private final class EchoWebSocketListener extends WebSocketListener {

    @Override

    public void onOpen(WebSocket webSocket, Response response) {

        webSocket.send("hello world");

        webSocket.send("welcome");

        webSocket.send(ByteString.decodeHex("adef"));

     //   webSocket.close(1000, "再见");

    }

    @Override

    public void onMessage(WebSocket webSocket, String text) {

     //   logger.e("onMessage","onMessage: " + text);

    }

    @Override

    public void onMessage(WebSocket webSocket, ByteString bytes) {

 //   logger.e("onMessage","onMessage: " + text);    }

    @Override

    public void onClosing(WebSocket webSocket, int code, String reason) {

     //   webSocket.close(1000, null);

    //   logger.e("onClosing","onClosing: " + reason);

    }

    @Override

    public void onClosed(WebSocket webSocket, int code, String reason) {

     //   logger.e("onClosed","onClosed: " + reason);

    }

    @Override

    public void onFailure(WebSocket webSocket, Throwable t, Response response) {

       //   logger.e("onFailure","onFailure: " + t.toString+response.toString);

    }

}

重写了WebSocketListener中的几个方法,这几个方法很好理解,是用来异步回调的,这里简单说一下:

onOpen当WebSocket和远程建立连接时回调;

两个onMessage就是接收到消息时回调,只是消息内容的类型不同;

onClosing是当远程端暗示没有数据交互时回调(即此时准备关闭,但连接还没有关闭,注意,此时并没有关闭);

onClosed就是当连接已经释放的时候被回调;

onFailure当然是失败时被回调(包括连接失败,发送失败等)。

步骤三:

private void connect() {

    EchoWebSocketListener listener = new EchoWebSocketListener();

    Request request = new Request.Builder()

            .url("ws://echo.websocket.org")

            .build();

    OkHttpClient client = new OkHttpClient();

//    开启

    client.newWebSocket(request, listener);

//关闭

//    client.dispatcher().executorService().shutdown();

}

如果打印成功,就说明整个简单的流程走通啦。

如果这个时候出现SSL  HandShake的问题 ,那么你需要忽略证书:

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("SSL");

        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.hostnameVerifier(new HostnameVerifier() {

@Override

            public boolean verify(String hostname, SSLSession session) {

return true;

            }

});

        return builder.build();

    }catch (Exception e) {

throw new RuntimeException(e);

    }

}

将以上 OkHttpClient client = new OkHttpClient();

替换为OkHttpClient client =getUnsafeOkHttpClient();

即可运行

祝君好运

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • <!DOCTYPE html> 查看源 window.WRM=window.WRM||{};window....
    SMSM阅读 897评论 1 0
  • WebSocket协议是一种建立在TCP连接基础上的全双工通信的协议。应用于即时通信等场景。 全双工通信:客户端和...
    fengfancky阅读 6,990评论 1 1
  • 英文文档,一开始我也是抗拒的,边翻译边看,也就花费了1个小时基本就阅读过了,我的英文基础其实很差。附上链接:链接:...
    lonecolonel阅读 10,014评论 3 1
  • 最近实际项目需要处理网络请求(一般是个app都会有的),于是接触了okhttp,目前也就刚刚会使用的程度,不...
    风二叽阅读 732评论 0 1
  • 这篇文章主要讲 Android 网络请求时所使用到的各个请求库的关系,以及 OkHttp3 的介绍。(如理解有误,...
    小庄bb阅读 1,226评论 0 4