0

I have been working in a chat app using nodejs and socket.io. I already have an Android client that works perfect in this schema. I started to use express.io instead of use express an socket.io separately. Everything works well except for my Android client. Im using https://github.com/socketio/socket.io-client-java socket client in Android, but my app never connect to my socket server.

I received the following error: io.socket.engineio.client.EngineIOException: server error

Does anybody knows something about this issue?

Server side config:

    var express = require('express.io');
    var path = require('path');
    var logger = require('morgan');
    var bodyParser = require('body-parser');
    var multer  = require('multer');

    var app = express();

    app.http().io()


    app.io.route('storeClientInfo', function(req) {

        req.io.join(req.io.request.data.customId);

    });

    app.io.route('enviar_room', function(req) {

      app.io.room(req.params.correo).broadcast('new visitor');

    });

    // Start the server

    app.set('port', process.env.PORT || 3000);

      var server = app.listen(app.get('port'), function() {
       console.log('Express server listening on port ' +                                     server.address().port);
      });

Android side:

    @Override
    protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    try {

        mSocket = IO.socket(LoginActivity.URL_HOST);
        mSocket.on(Socket.EVENT_CONNECT_ERROR, onConnectError);
        mSocket.on("new visitor",onNuevoMensaje);
    }
    catch(Exception ex)
    {
      ex.printStackTrace();
    }
    }

    private Emitter.Listener onConnectError = new Emitter.Listener() {
    @Override
    public void call(Object... args) {

        Log.d("SocketMsg: ", args[0].toString());

        for (Object o : args) {
            Log.i("IO " + Socket.EVENT_CONNECT_ERROR, o.toString());
        }

        runOnUiThread(new Runnable() {
            @Override
            public void run() {
                Toast.makeText(getApplicationContext(),
                        "CONNECT ERROR", Toast.LENGTH_LONG).show();


            }
        });
    }
};

Currently I already have a Angularjs web version running with my server. The problem is that in Android i always received Socket.EVENT_CONNECT_ERROR.

4

1 回答 1

0

经过两天的测试,我发现问题在于 Express.io 包含一个 socket.io 版本 0.9.6。socket.io-client-java 库 ( https://github.com/socketio/socket.io-client-java ) 支持 socket.io 1.x 或更高版本。我手动将 Express.io 上的 socket.io 版本更改为 1.3.7 版本。我只需要修改 Express 库中的部分代码。

于 2015-12-23T14:44:07.773 回答