【问题标题】:Nodejs+Expressjs+SocketIO on Heroku gives GET /socket.io/?EIO... 404Heroku 上的 Nodejs+Expressjs+SocketIO 提供 GET /socket.io/?EIO... 404
【发布时间】:2014-11-08 19:25:49
【问题描述】:

我在设置 socketIO 1.1 以在 Heroku 上工作时遇到问题。我正在运行 Express v4.2。 socketio 在 localhost 上完美运行。但是,在 Heroku 上,它给出了这个错误:

来自 Heroku 日志:

2014-09-15T09:40:14.578660+00:00 app[web.1]: GET /socket.io/?EIO=3&transport=polling&t=1410774014583-86 404 6ms - 744b

来自浏览器:

GET http://[mydomainname]/socket.io/?EIO=3&transport=polling&t=1410774080589-97 404 (Not Found) socket.io.js:2680Request.create socket.io.js:2680Request socket.io.js:2614XHR.request socket.io.js:2555XHR.doPoll socket.io.js:2585Polling.poll socket.io.js:2951Polling.doOpen socket.io.js:2895Transport.open socket.io.js:2106Socket.open socket.io.js:1580Socket socket.io.js:1467Socket socket.io.js:1419Manager.open.Manager.connect socket.io.js:272(anonymous function)

我已遵循 Socket IO 文档中的推荐配置。相关代码如下:

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

var path = require('path');
var favicon = require('static-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var cons = require('consolidate');

var app = express();

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

app.use(favicon());
app.use(logger('dev'));

app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
app.use(cookieParser('hashionhashion'));
app.use(require('less-middleware')(path.join(__dirname, 'public')));
app.use(express.static(path.join(__dirname, 'public')));

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


/// catch 404 and forward 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: {}
    });
});



//start the server
var server = require('http').Server(app);

var io = require('socket.io').listen(server);
var ioSockets = {};

io.on('connection', function(socket) {

    ioSockets[socket.id] = socket;

    socket.emit('welcome', {message: socket.id});

    socket.on('disconnect', function(socket) {
        delete ioSockets[socket.id];
    });
});

exports.ioSockets = ioSockets;
module.exports = app;

server.listen(3000, function() {
    console.log('Congrats, nothing broke!! Listening on port %d', server.address().port);
});

在我的客户端文件中,脚本如下:

<script src="my_path_to/socket.io.js"></script>
<script>
var socket = io.connect();

var socketId = '';

socket.on('welcome', function (data) {
    socketId = data.message;
});
</script>

我还尝试了 io.connect 到 "http://localhost""http://localhost:3000" 和我的 Heroku 应用程序域。它们都产生相同的错误。

任何帮助将不胜感激!

【问题讨论】:

  • 你真的解决了这个问题吗?
  • 在下面查看我接受的答案。
  • 我做到了。但要么我没有得到它,要么在 heroku 中更新 express 对我不起作用
  • 很抱歉我不使用heroku。那时它曾经与套接字有一些问题,我不知道现在是否仍然如此。但无能为力..

标签: node.js sockets heroku


【解决方案1】:

这个问题最终是一个快递问题,后来在4.10.0之后的版本中得到了纠正。

供您自己阅读: https://github.com/strongloop/express/issues/2406 https://github.com/jshttp/on-finished/issues/10

【讨论】:

    【解决方案2】:

    看起来你改变了 socket.io 路径。因为我看到了src="my_path_to/socket.io.js"。 socket.io 尝试连接但得到 404。

    是否有快速处理'/socket.io/'的路线?

    即使您解决了 404 错误。您将遇到另一个错误。因为目前在 heroku 上,您必须将 socket.io 连接到 https 地址。否则socket.io会在轮询下工作。

    更多细节: https://github.com/Automattic/engine.io/issues/261

    【讨论】:

    • 感谢您的评论。是的,确实有一个“包罗万象”的路由处理程序。但是,我确实尝试禁用处理 socketio 的路由。 router.get('/:user', function(req, res, next) { if(req.params.user === 'socket.io') { return next(err); } });我以为socket.io默认使用轮询?
    • socket.io 1.x 有两个默认传输 ['polling', 'websocket']。它首先使用轮询连接到服务器。然后服务器告诉客户端:'您需要升级(HTTP 状态 100)'。客户收到这个然后升级。升级操作发生在一个 http 请求中。包括稍后发出的数据。多合一连接。问题是 heroku 在没有 SSL 的情况下不支持像这样的粘性连接。
    猜你喜欢
    • 2017-12-25
    • 2021-07-09
    • 2013-07-18
    • 2017-02-25
    • 2018-09-10
    • 2017-09-04
    • 2020-11-24
    • 1970-01-01
    • 2011-10-13
    相关资源
    最近更新 更多