我尝试将 socket.io id 用于多个浏览器窗口/页面。它用于使用everyauth的 SNS-auth-process ,该项目基于express。
这是我的项目设计:
维护 socket.io 连接的完整 ajax 主页。没有重新加载,没有重定向等。
当用户尝试通过某个 SNS 帐户登录时,会打开一个弹出窗口,该窗口将由everyauth 和 SNS Auth 管理。在弹出窗口内,会发生许多重定向,但主窗口是持久的,socket.io 连接也是如此。
最后,授权成功后,everyauth 在弹窗中重定向'authdone.html'。
在浏览器上,这个弹窗已经没用了,所以 window.close();
但是,可以通过everyauth 获得成功的登录信息,但在我的情况下,cookie 更重要,因为我并不完全需要使用 express 框架进行会话管理,因为我打算通过 socket.IO 进行会话管理。
app.get('*',
function (req, res)
{
console.log("----------get------------");
console.log(req.url);
if (req.url == '/public/authdone.html')
{
console.log("----------get /public/authdone.html------------");
console.log(req.cookies);
// express(connect) sessionID(sid) cookie available here.
//{ 'connect.sid': '2DLlayNx90wtTsyeq5w83N9g.Kc1ZFd8I7omf6u4fk4FFyKAt4dP1V6IufSf1ZtRudVI' }
}
onreq(req, res);
});
目前,我设法通过重定向到登录页面(/public/authdone.html)的弹出窗口上的cookie获得了快速会话ID,但是,这还不够。我还需要在 cookie 中获取面向 socket.IO 的 ID。
实际上,我在这里感到困惑,并提出了一个问题。 在 Socket.IO 上添加 cookie 值
感谢 Wes,我稍微找到了一种添加新 cookie 值的方法(在我的情况下,是一些套接字客户端 ID),如下所示:
io.configure(function ()
{
io.set('authorization', function (handshake, callback)
{
if (handshake.headers.cookie)
{
var cookie = handshake.headers.cookie;
var newS = ";"
+ "socketClientID" + "="
+ "999999999999999";// eventually randomize for every client
cookie += newS;
console.log("=========================================");
console.log(cookie);
} else
{
return callback('Cookie not found', false);
}
callback(null, true);
});
});
在这个块中,我添加了一个 cookie 值作为“socketClientID=999999999999999”
所以当前通过 console.log 输出的 cookie 是
connect.sid=fc2iTJW3ETD7nIyxI5ZwpayK.S0qGhp1Ryw7Msg2r03yB6g822qVZIZTbZyWUSpQL0aU;
socketClientID=999999999999999
到目前为止一切顺利,但是,在everyauth 重定向页面上,我仍然得到
----------get /public/authdone.html------------
{ 'connect.sid': 'fc2iTJW3ETD7nIyxI5ZwpayK.S0qGhp1Ryw7Msg2r03yB6g822qVZIZTbZyWUSpQL0aU' }
只能通过 cookie 获取 express sessionID(connect.sid),socket.IO 握手阶段添加的 clientID cookie 值不反映。
我真的需要帮助。谢谢。