node.js - Socket.io已连接但无法通信

标签 node.js sockets socket.io

我在安装了socket.io的节点服务器中有一个非常简单的配置(稍微复杂一点,但本质上是这样的):

var main = require('express')();
    server = require('http').createServer(main);
    io = require('socket.io')(server);

io.use(function(socket, next) {
  console.log("middleware!");
  next();
});

io.on('connection', function (socket) {
  console.log('connected...');

  socket.on('pong', function (data) {
    console.log(data.message);
  });

  setTimeout(function() {
    console.log("Saying hello");
    socket.emit('ping', { message: 'Hello from server ' + Date.now() });

  }, 1000);

});

server.listen(2080, function onCreateServerMain() {
  console.log('Server main is listening on port 2080';
  console.log('************************************************************');
});

在客户端中:
var socketIoScript,
    loadSocketTimeout,
    trialsToLoadSocketIo = 0,
    APP_CFG = {baseUrl : "http://192.168.1.13:2080"};

function loadSocketIo(socketIoIp) {
  socketIoScript = document.createElement('script');
  socketIoScript.setAttribute('src', socketIoIp);
  socketIoScript.setAttribute('onload', 'onSocketLoaded();');
  document.head.appendChild(socketIoScript);
}

window.onSocketLoaded = function onSocketLoaded() {
  if (typeof(io.connect) === 'function') {
    var mSocket,
        mIoSocket;

    $timeout.cancel(loadSocketTimeout);
    mIoSocket = new io.Manager(APP_CFG.baseUrl);

    mIoSocket.connect(function(socket) {
      console.log('Connected!!');
    });
    mIoSocket.on('error', function onSocketError(e) {
      console.log('WebSocket Error ' + error);
    });

    mIoSocket.on('ping', function onPingReceived(e) {
      console.log('Server emitted ping: ' + e.data);
      mSocket.emit('pong', 'hi server!');
    });
  }
}

~(function onLoadSocketTimeout() {
  var nextTimeout;

  if (trialsToLoadSocketIo < 10) {
    nextTimeout = 5000;
  } else if (trialsToLoadSocketIo > 60) {
    nextTimeout = 60000;
  } else {
    nextTimeout = 1000 * trialsToLoadSocketIo;
  }

  if (socketIoScript) {
    document.head.removeChild(socketIoScript);
  }

  loadSocketIo(APP_CFG.baseUrl + '/socket.io/socket.io.js#' + trialsToLoadSocketIo);
  loadSocketTimeout = $timeout(onLoadSocketTimeout, nextTimeout);
  trialsToLoadSocketIo += 1;
})();

(我这样做是因为它是移动应用程序,因此可能没有连接)。我正在使用Brackets和Chrome进行测试。服务器和客户端在同一台计算机上。在应用程序中,脚本可以很好地加载,并且可以连接到服务器,正如我在节点日志中看到的那样(编辑:这是我在节点控制台中获得的所有信息):
Server main is listening on port 2080
************************************************************
middleware!
connected...
Saying hello

编辑:在Chrome控制台中,我没有收到任何消息,并且任何断点都在on监听器处停止。如果我停止节点,Chrome的控制台将立即开始记录已断开连接:
GET http://192.168.1.13:2080/socket.io/?EIO=3&transport=polling&t=1413066902601-6 net::ERR_CONNECTION_REFUSED 
GET http://192.168.1.13:2080/socket.io/?EIO=3&transport=polling&t=1413066906606-7 net::ERR_CONNECTION_REFUSED 

但是我看不到任何传入消息。在应用程序中,我没有收到任何传入消息。有什么原因即使成功连接套接字也无法在这种环境下通信?

编辑

没有应用程式正在接收对方发送的事件。来自节点的日志显示了这一点,来自Chrome的日志为空。

编辑

在Chrome应用中,我没有收到console.log("Connected!");。但是我都没有收到ERR_CONNECTION_REFUSED错误:我什么也没收到。

编辑

我设法通过更改Manager选项在应用程序中获取console.log("Connected!");:
  mIoSocket = new io.Manager(APP_CFG.baseUrl, { autoConnect: false });

由于它是自动连接,并且在建立连接后附加了事件,所以从未达到“已连接”。但是我仍然没有在任何应用程序中收到任何事件。

最佳答案

好的,几件事:

首先,var mSocket似乎没有初始化,因此它可能很难发出()任何东西(我错过了什么吗?)

其次,当您执行以下操作时:

socket.on('pong', function (data) {
    console.log(data.message);
});

服务器希望接收到一个包含message属性的对象,例如:data = {message:'hi server'}在您的情况下,您发送一个字符串,因此data'Hi server !',并且您的日志将显示“undefined”。您应该将此位更改为:
socket.on('pong', function (data) {
    console.log(data);
});

如果您遇到类似的问题,则发送一个对象:{ message: 'Hello from server ' + Date.now() },并尝试记录一个不存在的data属性。将此位更改为:
  console.log('Server emitted ping: ' + e.message);

第三,您必须监听套接字上的事件,而不是'manager'

客户:
mIoSocket.connect(function(socket) {
    console.log('Connected!!');
    socket.emit('pong');

    socket.on('error', function onSocketError(e) {
        console.log('WebSocket Error ' + error);
    });

    socket.on('ping', function onPingReceived(e) {
        console.log('Server emitted ping: ' + e.data);
        socket.emit('pong', 'hi server!');
    });
});

服务器:
io.on('connection', function (socket) {
  console.log('connected...');

  socket.on('pong', function (data) {
    console.log(data);
  });

  setTimeout(function() {
    console.log("Saying hello");
    socket.emit('ping', { message: 'Hello from server ' + Date.now() });

  }, 1000);

});

关于node.js - Socket.io已连接但无法通信,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26319931/

相关文章:

node.js - NodeJS - TCP Net 和 HTTP 服务器都会因错误而崩溃吗?

node.js - 如何逐行读取并检测eof(文件结尾)?

c++ - 从套接字在线程中接收消息

c++ - 如何在crypto++中使用SocketSource和SocketSink

python-3.x - 后台任务不发出

node.js - Express:从另一个中间件调用一个中间件

node.js - Angular 7 浏览器未反射(reflect)代码中所做的更改

android - Android VpnService是如何保护fd工作的?

node.js - 使用 Node Express 生成器配置 socket.io

socket.io + sencha 中的 javascript 命名空间问题