Как получить доступ к сеансу в экспресс, вне пределов запроса? - PullRequest
21 голосов
/ 18 июня 2011

Я знаю, что могу использовать

function(req, res) {
    req.session
}

с использованием экспресс. Однако мне нужно получить доступ к сеансу вне функции ответа. Как бы я поступил так?

Я использую socket.io для передачи информации для добавления постов и комментариев. Поэтому, когда я получаю сообщение socket.io на стороне сервера, мне нужно проверить человека, публикующего информацию, используя сеанс. Однако, поскольку это делается через socket.io, req / res отсутствует.

Ответы [ 4 ]

10 голосов
/ 19 июня 2015

Мне кажется, у меня другой ответ.

код:

var MongoStore = require('connect-mongo')(session);
var mongoStore = new MongoStore({
    db:settings.db,            //these options values may different
    port:settings.port,
    host:settings.host
})
app.use(session({
    store : mongoStore
    //here may be more options,but store must be mongoStore above defined
}));

тогда вы должны определить сеансовый ключ в req, как:

код:

req.session.userEmail;

наконец, вы можете получить это так:

код:

var cookie = require("cookie"); //it may be defined at the top of the file
io.on("connection",function(connection){

 var tS = cookie.parse(connection.handshake.headers.cookie)['connect.sid'];
 var sessionID = tS.split(".")[0].split(":")[1];
 mongoStore.get(sessionID,function(err,session){
      console.log(session.userEmail);
 });
}

Я вчера проверил это, оно работало хорошо.

7 голосов
/ 07 января 2012

Используя socket.io, я сделал это простым способом.Я предполагаю, что у вас есть объект для вашего приложения, скажем, MrBojangle, для моего он называется Shished:

/**
 * Shished singleton. 
 *
 * @api public
 */
function Shished() {
};


Shished.prototype.getHandshakeValue = function( socket, key, handshake ) {                          
    if( !handshake ) {
        handshake = socket.manager.handshaken[ socket.id ];                                         
    }
    return handshake.shished[ key ];                                                                
};                                                                                                  

Shished.prototype.setHandshakeValue = function( socket, key, value, handshake ) {                   
    if( !handshake ) {
        handshake = socket.manager.handshaken[ socket.id ];                                         
    }
    if( !handshake.shished ) {
        handshake.shished = {};                                                                     
    }
    handshake.shished[ key ] = value;                                                               
};

Затем в вашем методе авторизации я использую MongoDB для хранения сессии:

io.set('authorization', function(handshake, callback) {
    self.setHandshakeValue( null, 'userId', null, handshake );
    if (handshake.headers.cookie) {
        var cookie = connect.utils.parseCookie(handshake.headers.cookie);
        self.mongoStore()
        .getStore()
        .get(cookie['connect.sid'], function(err, session) {
            if(!err && session && session.auth && session.auth.loggedIn ) {
                self.setHandshakeValue( null,
                            'userId',
                            session.auth.userId,
                            handshake );
            }
        });
    }

Затем перед сохранением записи в модели вы можете сделать:

model._author = shished.getHandshakeValue( socket, 'userId' );

1 голос
/ 16 декабря 2011

Я полагаю, что проверка socket.handshake даст вам сеанс:

io.sockets.on('connection', function(socket) { 
  console.log(socket.handshake.sessionID);
});

Когда клиент устанавливает соединение через сокет с вашим сервером socket.io, клиент отправляет запрос на рукопожатие WebSocket.То, что я делаю выше, это получение идентификатора сеанса из рукопожатия.

0 голосов
/ 19 июня 2011

Предполагается, что ваш код socket.io выглядит примерно так:

io.on('connection',
function(client) {
  console.log(client.request)
});

Запрос client.request, как показано в примере выше.

Редактировать: возможно, как отдельную вещьэто поможет: https://github.com/aviddiviner/Socket.IO-sessions

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...