之一897
2022-01-25 16:56
采纳率: 33.3%
浏览 37

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条)

相关推荐 更多相似问题