socket.io客户端事件未触发

时间:2019-11-20 23:26:30

标签: websocket socket.io sails.js

我正在尝试在未连接服务器的情况下运行客户端(故意)并捕获ERR_CONNECTION_REFUSED错误并将其显示给用户。我读过here,这可以通过套接字事件来实现,特别是connect_error

在我的代码下面,我永远无法触发事件并在其中显示控制台日志。记录this.io.socket可以打印内容,但是没有任何事件可以。.为什么?

$.ajax(args)
        .done((msg) => {
          this.io.socket.on('connect', msg => {
            console.log('connect socket io', msg)
          })
          resolve(msg);
        })
        .fail((jqXHR, msg) => {
          return new Promise((resolve, reject) => {
            console.log('inside promise of fail() - this.io.socket', this.io.socket) // this will log data to console

            this.io.socket.on('connect_error', msg => {
              console.log('connect_error socket io', msg)
            })

            this.io.socket.on('connect_failed', (msg) => {
              console.log('connect_failed', msg);
            });

            // return some error here for user
          })
        });

1 个答案:

答案 0 :(得分:0)

据我所知,只有在您的第一个ajax 调用收到错误响应时,您才尝试连接事件处理程序。这不会导致任何socket.io事件处理程序被启动。

将事件处理程序移动到初始化套接字实例的代码中。

请参见下面的完整示例,其中所有managersocket事件都将记录到控制台。

$.ajax(args)
    .done((msg) => {
        // connect to your server
        const socket = io('http://localhost:3000', {
            transports: ['websocket']
        });

        // manager events
        //_________________________________________________________________________________________________
        socket.io.on('connect_error', (err) => {
            console.error(`manager:connect_error ${err}`);
        });

        socket.io.on('connect_timeout', () => {
            console.error(`manager:connect_timeout`);
        });

        socket.io.on('reconnect_attempt', (attempt) => {
            console.error(`manager:reconnect_attempt ${attempt}`);
        });

        socket.io.on('reconnecting', (attempt) => {
            console.error(`manager:reconnecting ${attempt}`);
        });

        socket.io.on('reconnect_error', (err) => {
            console.error(`manager:reconnect_error ${err}`);
        });

        socket.io.on('reconnect_failed', () => {
            console.error(`manager:reconnect_failed`);
        });
        //_________________________________________________________________________________________________

        // socket events
        //_________________________________________________________________________________________________
        socket.on('connect', () => {
            console.log(`socket:connect ${socket.connected}`);
        });

        socket.on('connect_error', (err) => {
            console.error(`socket:connect_error ${err}`);
        });

        socket.on('connect_timeout', (timeout) => {
            console.error(`socket:connect_timeout ${timeout}`);
        });

        socket.on('error', (err) => {
            console.error(`socket:error ${err}`);
        });

        socket.on('disconnect', (reason) => {
            console.info(`socket:disconnect ${reason}`);
            if (reason === 'io server disconnect') {
                // the disconnection was initiated by the server, you need to reconnect manually
                socket.connect();
            }
            // else the socket will automatically try to reconnect
        });

        socket.on('reconnect', (attempt) => {
            console.error(`socket:reconnect ${attempt}`);
        });

        socket.on('reconnect_attempt', (attempt) => {
            console.error(`socket:reconnect_attempt ${attempt}`);
        });

        socket.on('reconnecting', (attempt) => {
            console.error(`socket:reconnecting ${attempt}`);
        });

        socket.on('reconnect_error', (err) => {
            console.error(`socket:reconnect_error ${err}`);
        });

        socket.on('reconnect_failed', () => {
            console.error(`socket:reconnect_failed`);
        });
        //_________________________________________________________________________________________________

        // custom events
        //_________________________________________________________________________________________________
        socket.on('hello', (message) => {
            console.info(message);

            socket.emit('hello', {foo: 'baz'});
        });
        //_________________________________________________________________________________________________

        resolve(msg);
    })
    .fail((jqXHR, msg) => {
        console.error(msg);
    });