Socket.io 0.9使用Gottox / socket.io-java-client在Android上发出响应

时间:2015-02-04 09:32:55

标签: java android sockets socket.io gottox

如果有人可以告诉我,我的代码有什么问题? 我真的花了很多时间试图找出这个问题。 在成功连接到服务器后,您可以在日志中看到的“chatinfo”事件自动传递。

我用: Android设备上的Gottox/socket.io-java-clienthttp://socket.io/ 0.9.16在服务器上, 授权是通过在连接建立的头文件中传递令牌。

代码:

private void getList(SocketIO socket) {
    try {
        socket.emit(EventList.GETLIST, new JSONObject().put("sortByDate", true));
        Log.v("getList", "emitted");
    } catch (JSONException e) {
        e.printStackTrace();
        Log.v("getList", "not emitted");
    }
} 

代码:

@Override
public void on(String s, IOAcknowledge ioAcknowledge, Object... objects) {
    JSONObject respond = (JSONObject) objects[0];
    Log.d("testFromOn", "String s = " + s);
    Log.d("testFromOn", "on" + respond);
    switch (s) {
        case GETLIST:
            Log.d("GETLIST", "GETLIST responce: " + s);
            break;

日志

I/io.socket﹕ < 1::
D/test﹕ onConnect
I/io.socket﹕ < 5:::{"name":"chatinfo","args":[{"onlineCount":0,"onlineFriendsCount":0,"unreadCount":7,"unreadFriendsCount":0,"userInfo":{"avatar":"1415903272343.jpg","url":"/user/5431b4955518085d5db4be23","_id":"5431b4955518085d5db4be23"}}]}
D/testFromOn﹕ String s = chatinfo
D/testFromOn﹕ on{"onlineCount":0,"onlineFriendsCount":0,"unreadCount":7,"unreadFriendsCount":0,"userInfo":{"avatar":"1415903272343.jpg","url":"\/user\/5431b4955518085d5db4be23","_id":"5431b4955518085d5db4be23"}}
I/io.socket﹕ > 5:::{"name":"getlist","args":[{"sortByDate":true}]}
V/getList﹕ emitted
I/io.socket﹕ > 2::
I/io.socket﹕ > 5:::{"name":"getlist","args":[{"sortByDate":true}]}
V/getList﹕ emitted
I/io.socket﹕ < 2::
I/io.socket﹕ > 2::

1 个答案:

答案 0 :(得分:1)

最后我的问题不是真正的问题。我只是想错过在我的发射中添加一个参数。所以没有人抓住服务器的回应。

唯一要补充的是:

IOAcknowledge ack = new IOAcknowledge() {
@Override
public void ack(Object... args) {
    if (args.length > 0) {
        Log.d("SocketIO", "" + args[0]);
    }
}
}

并将IOAcknowledge传递给emit方法:

socket.emit(EventList.GETLIST, ack, new JSONObject().put("sortByDate", true));