之一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日

悬赏问题

  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 r语言蛋白组学相关问题
  • ¥15 Python时间序列如何拟合疏系数模型
  • ¥15 求学软件的前人们指明方向🥺
  • ¥50 如何增强飞上天的树莓派的热点信号强度,以使得笔记本可以在地面实现远程桌面连接
  • ¥20 双层网络上信息-疾病传播
  • ¥50 paddlepaddle pinn
  • ¥20 idea运行测试代码报错问题
  • ¥15 网络监控:网络故障告警通知