【问题标题】:socket.io not working with node serversocket.io 无法与节点服务器一起使用
【发布时间】:2017-06-29 21:47:18
【问题描述】:

我正在尝试设置我的节点服务器以实时更新所有连接的客户端的新信息。当我运行下面的代码时,io.sockets.on('connection') 回调不断被触发,消息Client connected! 淹没了控制台,并且前端没有从socket.emit() 更新。我做错了什么?

app.js

var express = require('express');
var path = require('path');
var favicon = require('static-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var mongoose = require('mongoose');
var models = require('./models.js');

var routes = require('./routes/index');
var users = require('./routes/users');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');

app.use(favicon());
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);
app.use('/users', users);

/// catch 404 and forwarding to error handler
app.use(function(req, res, next) {
    var err = new Error('Not Found');
    err.status = 404;
    next(err);
});

/// error handlers

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
    app.use(function(err, req, res, next) {
        res.status(err.status || 500);
        res.render('error', {
            message: err.message,
            error: err
        });
    });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
        message: err.message,
        error: {}
    });
});

module.exports = app;

// Connect to the Mongo database
mongoose.connect('mongodb://localhost/test');

bin/www.js

#!/usr/bin/nodejs
var debug = require('debug')('my-application');
var app = require('../app');

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

var io = require('socket.io').listen(app.listen(app.get('port')));

io.sockets.on('connection', function(socket) {
  console.log('Client connected!');
  socket.on('message', function(data) {
    console.log('Sending update!');
    socket.emit('update', 'Working!');
  });
});

public/javascripts/update.js

var socket = io.connect('http://' + document.location.hostname + ':3000/');

socket.on('connect', function() {
  console.log('Socket connected!');
  socket.emit('message', 'Message from client');
});

socket.on('update', function(data) {
  alert(data);
});

当我结束 npm 进程时,客户端开始记录

http://<ip>:3000/socket.io/?EIO=2&transport=polling&t=1498772846992-691 net::ERR_CONNECTION_REFUSED

我已经阅读了有关快速路由器与套接字请求混淆的帖子,但无论我尝试什么,我似乎都无法让它工作。

【问题讨论】:

  • 您能否更新问题的标题以描述您需要帮助的问题,而不是您正在使用的工具?

标签: javascript node.js sockets express socket.io


【解决方案1】:

你能试试这个设置吗?

已编辑:

app.js:

var express = require('express');
var app = express();
app.set('views', __dirname + '/views');
app.set('view engine', 'pug');
app.get('/', function (req, res) {
    res.render('index');
});

module.exports = app;  

bin/www.js:

var app = require('../app');
var http = require('http');
var server = http.createServer(app);
server.listen(process.env.PORT || '3000', function () {
    console.log('server listens on port 3000');
});
var io = require('socket.io')(http);
io.listen(server);

io.on('connection', function(socket) {
    console.log('Client connected!');
    socket.on('message', function (data) {
        console.log('Sending update!');
        socket.emit('update', 'Working!');
    });
});

index.pug(或玉,他们说玉已过时):

doctype html
html
  body
    h1 Testing socket.io
    h3#status not connected 
    br  
    p#update update:&nbsp

    script(src="/socket.io/socket.io.js")
    script.
      var socket = io();
      socket.on('connect', function() {
        document.getElementById("status").innerHTML = "connected";   
        socket.emit('message', 'Hello!');
      });
      socket.on('update', function (data) {
          document.getElementById("update").innerHTML += data;  
      });

【讨论】:

  • 我觉得似乎好一点...现在Client connected 消息在客户端实际连接时准确记录了 6 次,并且在您等待时随机记录了几次
  • 谢谢它的工作!我认为我的问题是我在客户端使用 cdn 包含socket.io,而不是/socket.io/socket.io.js。进行该更改修复它。
  • 我不这么认为,cdn 也应该可以正常工作。将/socket.io/socket.io.js 替换为https://cdnjs.cloudflare.com/ajax/libs/socket.io/2.0.3/socket.io.js,将var socket = io(); 替换为var socket = io("http://localhost:3000");,一切正常。不同之处在于,当您使用 cdn 时,您必须指定服务器的 url,如果您使用本地 socket.io,客户端“知道”服务器地址。
【解决方案2】:

调用app.listen(其中app是调用express()的结果)返回一个HTTPServer,可用于设置套接字连接:

var server = app.listen(port);
var io = socket(server);

如果不手动运行您的解决方案,我猜是因为您正在创建一个新的 HTTPServer 以输入到套接字中,所以它会以某种方式陷入循环。

【讨论】:

  • 在您的“应用程序”和“www”js 文件中,您正在创建应用程序和 io 服务器引用。我的信念是您正在创建一个无限循环。为什么两者都有?
  • @jamesemanon 我从 app.js 中删除了额外的引用(原始帖子中的代码已更新),但我得到了同样的结果。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-11-04
  • 2020-10-04
  • 1970-01-01
  • 2014-09-03
  • 2011-10-17
  • 1970-01-01
相关资源
最近更新 更多