password.js中的多个会话

时间:2019-02-16 14:35:20

标签: node.js express passport.js

中间件设置

var session = require('express-session');
var passport = require('passport');
app.use(session({
secret: 'secret',
saveUninitialized: true,
resave: true
}));
app.use(passport.initialize());
app.use(passport.session());

我有两个单独的用户登录。一个是客户,另一个是商人

客户护照会话代码

var passport = require('passport');
var Strategy = require('passport-local').Strategy;
app.post('/login',
passport.authenticate('local', {successRedirect:'/customer/home',    failureRedirect:'/customer/login',failureFlash: true}),
function(req, res) {
  req.session.user=user;
  res.redirect('/customer/home');
});
passport.serializeUser(function(user, cb) {
cb(null, user._id);
});

passport.deserializeUser(function(id, cb) {
data.customerid(id, function (err, user) {
  if (err) { return cb(err); }
  cb(null, user);
});
});

passport.use(new Strategy(
function(username, password, cb) {
  data.customerlogin(username, function(err, user) {
    if (err) { 
        return cb(err); 
    }
    if (!user) {
         return cb(null, false); 
        }
    if (user.password != password) { 
        return cb(null, false); 
    }
    return cb(null, user);
});
}));

它正在为一个用户工作,如何为另一个用户的商家创建另一个会话

1 个答案:

答案 0 :(得分:0)

第一个问题可能是这个

function(req, res) {
  req.session.user=user;
  res.redirect('/customer/home');
});

user中的req.sessson.user = user很可能未定义。我建议您在这里查看您要实现的逻辑,然后重新检查代码是否实现了该逻辑。

只有一个会话可能更简单。会话将以客户角色或商人角色进行。然后,用户将可以根据角色访问Web应用程序的各个部分。