Android 简单的webSocket长连接

移动开发 专栏收录该内容
23 篇文章 0 订阅
  public static WebSocket webSocket;
    public OkHttpClient mOkHttpClient = new OkHttpClient.Builder().readTimeout(15000, TimeUnit.SECONDS)//设置读取超时时间
            .writeTimeout(15000, TimeUnit.SECONDS)//设置写的超时时间
            .connectTimeout(15000, TimeUnit.SECONDS)//设置连接超时时间
            .build();

    public void webSocket() {
        String url = "ws://websocket"; //服务端的地址
        Request request = new Request.Builder().url(url).build();
        WebSocketCall webSocketCall = WebSocketCall.create(mOkHttpClient, request);
        webSocketCall.enqueue(new WebSocketListener() {
            @Override
            public void onOpen(WebSocket webSocket, Response response) {
                Log.d("WebSocketCall", "onOpen");
                MainActivity.webSocket = webSocket;
                try {
                    webSocket.sendMessage(RequestBody.create(WebSocket.TEXT, "测试"));//发送内容
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }

            /**
             * 连接失败
             */
            @Override
            public void onFailure(IOException e, Response response) {
                Log.d("WebSocketCall", "onFailure");
            }

            /**
             * 接收到消息
             */
            @Override
            public void onMessage(ResponseBody message) throws IOException {
                try {
                    MyLog.e("message" + message.string());//接收实时内容
                } catch (Exception e) {
                    message.source().close();
                }
                message.source().close();
            }

            @Override
            public void onPong(Buffer payload) {
                Log.d("WebSocketCall", "onPong:");
            }

            /**
             * 关闭
             */
            @Override
            public void onClose(int code, String reason) {
                MyLog.e("onClose");
            }
        });
    }

源码下载地址

  • 2
    点赞
  • 4
    评论
  • 4
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

相关推荐
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值