Socket.io java 客户端多次收到相同的消息

Socket.io java client get same message more than one time

我在 android 聊天应用程序上使用 socket.io。为了保持连接有效,我在 main activity 中启动的服务中连接套接字。我检查套接字是否已连接。如果不是,我建立套接字连接。这是我的代码:

try {
        mSocket = IO.socket("http://192.168.x.x:XXXX");
    } catch (URISyntaxException e) {
        throw new RuntimeException(e);
    }

    if(!mSocket.connected()){   
        mSocket.connect();
    }

    mSocket.on("new message", onNewMessage);
    mSocket.on("user joined", onUserJoined);
    mSocket.emit("add user", "MobileUser");

    message += cal.get(Calendar.HOUR) + ":" + cal.get(Calendar.MINUTE);
    sendMessage();

public void sendMessage(){
     mSocket.emit("new message", message);
     addMessage("MobileUser", message);
}

连接完美。我的服务每分钟都使用套接字发送消息。这在其他客户端中似乎是这样的:

MobileUser: 1:11
MobileUser: 1:12
MobileUser: 1:13
MobileUser: 1:14
MobileUser: 1:15

我的问题是:在这5条消息之后(5次只是一个例子,可以是大于1的任何数字),如果其他客户端发送消息,我收到此消息 5 次。但我当然想收到此消息一次。我该如何处理这个问题?有什么建议吗?

编辑:

我的 onNewMessage 方法在客户端:

private Emitter.Listener onNewMessage = new Emitter.Listener() {
public void call(final Object... args) {
    Thread t = new Thread(new Runnable() {
        public void run() {
            JSONObject data = (JSONObject) args[0];
            try {
                username = data.getString("username");
                message = data.getString("message");
            } catch (JSONException e) {
                return;
            }

            Log.v(username, message);
        }
    });

    t.start();
  }
};

我服务器上的 "new message" 事件:

socket.on('new message', function (data) {
   console.log('message: ' + data);

   socket.broadcast.emit('new message', {
      username: socket.username,
      message: data
   });
});

我想我找到了解决办法。我应该检查我的服务中是否连接了套接字 class 但这些代码不应该在那里:

mSocket.on("new message", onNewMessage);
mSocket.on("user joined", onUserJoined);
mSocket.emit("add user", "MobileUser");

我从我的服务中删除了这些 class 并放置了 MainActivity class。问题已解决。