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

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 VMware 云桌面水印如何添加
  • ¥15 用ns3仿真出5G核心网网元
  • ¥15 matlab答疑 关于海上风电的爬坡事件检测
  • ¥88 python部署量化回测异常问题
  • ¥30 酬劳2w元求合作写文章
  • ¥15 在现有系统基础上增加功能
  • ¥15 远程桌面文档内容复制粘贴,格式会变化
  • ¥15 这种微信登录授权 谁可以做啊
  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”