Один и тот же идентификатор сеанса хранится в Cookie для нескольких пользователей (express-session, Passport.js) - PullRequest
0 голосов
/ 29 октября 2018

Я использую express-session и Passport.js (локальная стратегия) для аутентификации простого веб-приложения.

Поэтому, когда я проверяю заголовок запроса при входе в систему с разными пользователями, я вижу тот же идентификатор сеанса, что и значение Cookie:

Cookie: connect.sid="some_encrypted_string"

Разве cookie не должен быть уникальным для каждого пользователя?

Ниже приведена конфигурация для сеансов и паспортной аутентификации:

Промежуточное программное обеспечение экспресс-сеанса:

app.use(session({
    secret: 'somekey',
    resave: true,
    saveUninitialized: true
}));

Конфигурация паспорта:

const LocalStrategy = require('passport-local');
const bcrypt = require('bcryptjs');
const User = require('../models/user');

module.exports = function(passport) {
    passport.use(new LocalStrategy({usernameField: 'email'},
    (email, password, done) => {
        // Match User
        User.findOne({
            email: email
        }).then(user => {
            if(!user) {
                return done(null, false, {message: 'No user found'});  
            }

            // Match Password
            bcrypt.compare(password, user.password, (err, isMatch) => {
                if(err) throw err;

                if(isMatch) {
                    return done(null, user); 
                } else {
                    return done(null, false, {message: 'Password Incorrect'});
                }
            });
        }).catch(err => console.log(err));
    }));

    // Sessions
    passport.serializeUser(function(user, done) {
        done(null, user.id);
    });

    passport.deserializeUser(function(id, done) {
        User.findById(id, function(err, user) {
          done(err, user); 
        });
    });
}

Запрос на вход:

router.post('/login', (req, res, next) => {
    passport.authenticate('local', {
        successRedirect: '/ideas',
        failureRedirect: '/users/login',
        failureFlash: true
    })(req, res, next);
});

Я что-то упустил или моя концепция аутентификации неверна?

...