之一897 2022-01-25 16:56 采纳率: 25%
浏览 42
已结题

Android app开发建立Websocket 为什么不输出message?

主程序按下面写:

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

    //timer.schedule(task, 0, 200);
    URI uri = URI.create("ws://sq-test.icv-cloud.com:5000/。。。。。。。。");
    System.out.println(uri.toString());
    MyWebSocketClient myClient = new MyWebSocketClient(uri){
       @Override
          public void onMessage(String message) {
            Log.e("MyWebClientService", message);     //message就是接收到的消息
          }
    };

    try {
         myClient.connectBlocking();
    } catch (InterruptedException e) {
         e.printStackTrace();
      }

    if (myClient != null && myClient.isOpen()) {
        myClient.send("123");
    }
}

另建一个类按如下:

public class MyWebSocketClient extends WebSocketClient {
public MyWebSocketClient(URI serverUri) {
super(serverUri,new Draft_6455());}

@Override
public void onOpen(ServerHandshake handshakedata) {
    Log.e("MyWebSocketClient", "onOpen()");
    }

@Override
public void onMessage(String message) {
    Log.e("MyWebSocketClient", "onMessage()");
}

@Override
public void onClose(int code, String reason, boolean remote) {
    Log.e("MyWebSocketClient", "onClose()");
}

@Override
public void onError(Exception ex) {
    Log.e("MyWebSocketClient", "onError()");
}

打印出来的日志如下:

E/MyWebSocketClient: onClose()

按道理能打印出来:具体的messa的内容的?

是Websocket没有通吗?

  • 写回答

2条回答 默认 最新

  • 不会写代码的猴子 Android领域优质创作者 2022-01-25 17:14
    关注

    onClose不是有reason吗?打印出来看看

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月3日
  • 已采纳回答 1月26日
  • 修改了问题 1月25日
  • 创建了问题 1月25日

悬赏问题

  • ¥30 微信小程序蓝牙数据透传
  • ¥15 加氢站氢负荷数据集来源
  • ¥15 umi接入sentry遇到问题
  • ¥15 HBuilderX打包H5网页,扫码模块无法使用
  • ¥15 Javascript跳转页面后,无法执行后面代码,如何解决?
  • ¥15 echarts绘制图表
  • ¥15 请教两个关于高德地图定位不准的技术问题
  • ¥15 根据企业名称 对照两个文件 样本筛选/匹配
  • ¥15 Linux环境下CA证书更新问题
  • ¥15 sqlserver语句提取结果以外数据