13

我整个下午都在盯着 node.js 和 socket.io 的例子,我试图拼凑一个简单的页面,告诉我有多少用户连接到服务器。

我已经阅读了http://socket.io/上的文档以及这里的一些教程/问题,这些教程/问题概述了我正在尝试做的事情。我还发现创建简单的节点 js 服务器和客户端对我没有帮助。

版本信息:

node.js - 0.6.15
express - 3.0.0alpha1
socket.io - 0.9.5 (socket.io-client 是同一版本,但是找不到资源...见评论)
ejs - 0.7.1

这是我的服务器代码:

var express = require('express'),
    config = {
        port: 4000,
        hostname: 'localhost'
    };

var server = module.exports = express.createServer();
    /* server configuration */
    server.use(express.cookieParser('keyboard unicorn'));
    server.use(express.bodyParser());
    server.use(express.methodOverride());
    server.use(express.session({ secret: 'keyboard unicorn' }));
    server.engine('.html', require('ejs').__express);
    server.set('views', __dirname + '/lib/views');
    server.set('view options', { layout: false });
    server.set('view engine', 'html');
    server.use(server.router);
    server.use('/', express.static(__dirname + '/lib/assets'));

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

var connections = { 'length': 0 };

io.sockets.on('connection', function(socket) {
    socket.__fd = socket.fd;
    connections[socket.__fd]=socket.remoteAddress;
    ++connections.length;
    console.log('user connected! There are a total of ' + connections.length + ' users online.');
    return socket.on('disconnect',function(){
        delete conns[socket.__fd];
        --connections.length;
        console.log('user disconnected! There are a total of ' + connections.length + ' users remaining online.');
    });
});

server.get('/', function( req, res ) {
    res.render('index', {
        'page_title': 'sample application',
        'number_of_connections': connections.length
    });
});

server.listen(config.port, config.hostname);

这是我的客户代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title><%= page_title %></title>
</head>
<body>
<div>There is a total of <%= number_of_connections %> user(s) connected.</div>
<script src="http://cdn.socket.io/stable/socket.io.js"></script>
<script type="text/javascript">
var socket = new io.Socket('localhost',{'port':4000});
socket.connect();
socket.on('connect', function() {
    console.log('connected');
});
</script>
</body>
</html>

这是我运行服务器并与客户端连接时发生的情况。

$ node server.js
   info  - socket.io started

然后当我在我的网络浏览器上导航到 localhost:4000 时,我得到的页面是“0”(number_of_connections)。此外,我在服务器的终端中什么也看不到(on.('connection' 永远不会被击中)。

在客户端上,一两秒后,我开始收到大量错误(如果我让控制台打开几秒钟,它会使页面崩溃)见下图:

在此处输入图像描述

请,任何有关从哪里开始调试的帮助将不胜感激!我只想让这个基本示例启动并运行,这样我就可以开始使用/理解 nodejs 和 socket.io!

4

4 回答 4

21

问题是因为 Express 现在是一个函数。

您需要执行以下操作:

var express = require('express');
var app = express();
var server = app.listen(3000);

var io = require('socket.io').listen(server);
于 2012-04-21T13:54:33.627 回答
6

Express 3.0.0alpha 和 socket.io 不(直接)兼容,因为 Express 在 2.* 和 3.* 之间发生了变化(或者更确切地说,是 Connect 在 1.* 和 2.* 之间发生了变化)。我建议您暂时降级到 Express 2.5.9,或者您可以遵循Express 的作者 TJ Holowaychuk 的建议

于 2012-04-17T22:32:24.190 回答
4

我搭建了一个测试环境,安装了express 3.0和socket.io 0.9.5,重现了你的错误。

然后我npm install express@2.5.1根据迁移指南进行了一些向后调整,并且运行良好。

因此,我将继续建议 socket.io 可能与 express 3 不兼容,它看起来仍然很不稳定。

我的 app.js 针对 express 2 进行了调整:

var express = require('express'),
    config = {
    port: 8080,
    hostname: 'localhost'
};

var server = module.exports = express.createServer();
/* server configuration */
server.set('views', __dirname + '/lib/views');
server.set('view options', { layout: false });
server.set('view engine', 'ejs');
//server.register('.html', 'ejs');require('ejs').__express);
server.use(express.cookieParser('keyboard unicorn'));
server.use(express.bodyParser());
server.use(express.methodOverride());
server.use(express.session({ secret: 'keyboard unicorn' }));
server.use('/', express.static(__dirname + '/lib/assets'));
server.use(server.router);

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

io.set('log level', 2);

var connections = { 'length': 0 };

server.get('/', function( req, res ) {
        res.render('index', {
                'page_title': 'sample application',
                    'number_of_connections': connections.length
                    });
    });

io.sockets.on('connection', function(socket) {
        socket.__fd = socket.fd;
        connections[socket.__fd]=socket.remoteAddress;
        ++connections.length;
        console.log('user connected! There are a total of ' + connections.length + ' users online.');
        return socket.on('disconnect',function(){
                delete conns[socket.__fd];
                --connections.length;
                console.log('user disconnected! There are a total of ' + connections.length + ' users remaining online.');
            });
    });

server.listen(config.port);

我的 index.ejs 文件:

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="utf-8">
   <title><%= page_title %></title>
</head>
<body>
<div>There is a total of <%= number_of_connections %> user(s) connected.</div>
<!--<script src="http://cdn.socket.io/stable/socket.io.js"></script>-->
<script src='/socket.io/socket.io.js'></script>
<script type="text/javascript">
   var socket = io.connect('http://hostname.com:8080');
   socket.on('connect', function() {
      console.log('connected');
   });
</script>
</body>
</html>

我希望这里有帮助。

于 2012-04-17T22:47:35.140 回答
0

替换app.use(express.bodyParser());,用

app.use(express.json());
app.use(express.urlencoded());

...保存文件,重新启动节点服务器。

于 2014-01-29T17:54:36.797 回答