我正在尝试使用基于 cookie 的会话,但是它只能在本地机器上工作,而不是通过网络工作。如果我删除与会话相关的东西,它会在网络上很好地工作......
您必须原谅这里缺乏高质量的代码,我刚刚开始使用节点/套接字等,并且找到任何明确的指南都很难,所以我现在处于 n00b 领域。基本上,到目前为止,这是从各种片段中拼凑起来的,对我实际在做什么有大约 10% 的理解......
我在 Chrome 中看到的错误是:
socket.io.js:1632GET http://192.168.0.6:8080/socket.io/1/?t=1334431940273 500(内部服务器错误)
Socket.handshake -------- socket.io.js:1632
Socket.connect -------- socket.io.js:1671
套接字------- socket.io.js:1530
io.connect -------- socket.io.js:91
(匿名函数)------- /socket-test/:9
jQuery.extend.ready -------- jquery.js:438
在服务器的控制台中,我看到:
调试 - 提供静态内容 /socket.io.js
调试 - 授权
警告 - 握手错误 没有 cookie
我的服务器是:
var express = require('express')
, app = express.createServer()
, io = require('socket.io').listen(app)
, connect = require('express/node_modules/connect')
, parseCookie = connect.utils.parseCookie
, RedisStore = require('connect-redis')(express)
, sessionStore = new RedisStore();
app.listen(8080, '192.168.0.6');
app.configure(function()
{
app.use(express.cookieParser());
app.use(express.session(
{
secret: 'YOURSOOPERSEKRITKEY',
store: sessionStore
}));
});
io.configure(function()
{
io.set('authorization', function(data, callback)
{
if(data.headers.cookie)
{
var cookie = parseCookie(data.headers.cookie);
sessionStore.get(cookie['connect.sid'], function(err, session)
{
if(err || !session)
{
callback('Error', false);
}
else
{
data.session = session;
callback(null, true);
}
});
}
else
{
callback('No cookie', false);
}
});
});
var users_count = 0;
io.sockets.on('connection', function (socket)
{
console.log('New Connection');
var session = socket.handshake.session;
++users_count;
io.sockets.emit('users_count', users_count);
socket.on('something', function(data)
{
io.sockets.emit('doing_something', data['data']);
});
socket.on('disconnect', function()
{
--users_count;
io.sockets.emit('users_count', users_count);
});
});
我的页面 JS 是:
jQuery(function($){
var socket = io.connect('http://192.168.0.6', { port: 8080 } );
socket.on('users_count', function(data)
{
$('#client_count').text(data);
});
socket.on('doing_something', function(data)
{
if(data == '')
{
window.setTimeout(function()
{
$('#target').text(data);
}, 3000);
}
else
{
$('#target').text(data);
}
});
$('#textbox').keydown(function()
{
socket.emit('something', { data: 'typing' });
});
$('#textbox').keyup(function()
{
socket.emit('something', { data: '' });
});
});