Con l'ultima versione di connect (a partire dal 2012-07-26), ho trovato il seguente modo per ottenere un ID di sessione da socket.io funzionerà con un negozio di connessione redis.socket.io parse connect (> = 2.4.1) cookie di sessione firmato
var express = require('express')
, routes = require('./routes')
, fs = require('fs')
, http = require('http')
, io = require('socket.io')
, redis = require('connect-redis')
, connect = require('express/node_modules/connect')
, parseSignedCookie = connect.utils.parseSignedCookie
, cookie = require('express/node_modules/cookie');
var secret = '...';
var rStore = new(require('connect-redis')(express));
//...
var server = http.createServer(app);
var sio = io.listen(server);
sio.set('authorization', function(data, accept) {
if(data.headers.cookie) {
data.cookie = cookie.parse(data.headers.cookie);
data.sessionID = parseSignedCookie(data.cookie['connect.sid'], secret);
} else {
return accept('No cookie transmitted', false);
}
accept(null, true);
});
data.sessionID
può quindi essere utilizzato in seguito come
sio.sockets.on('connection', function(socket) {
console.log('New socket connection with ID: ' + socket.handshake.sessionID);
rStore.get(socket.handshake.sessionID, function(err, session) {
//...
});
});
dover importare tanti da espresso (connessione, un programma di utilità di connessione, e il modulo cookie) sembra un modo eccessivamente rotonda di ottenere le funzioni necessarie per analizzare i cookie firmati della connessione. Qualcuno ha trovato un altro modo?
Vorrei poter upvote questo 100+ volte. La tua soluzione sopra mi ha risparmiato un sacco di tempo, grazie per averlo pubblicato! Mi dispiace non posso suggerire un altro modo. – LDK