中间件设置
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);
});
}));
它正在为一个用户工作,如何为另一个用户的商家创建另一个会话
答案 0 :(得分:0)
第一个问题可能是这个
function(req, res) {
req.session.user=user;
res.redirect('/customer/home');
});
user
中的req.sessson.user = user
很可能未定义。我建议您在这里查看您要实现的逻辑,然后重新检查代码是否实现了该逻辑。
只有一个会话可能更简单。会话将以客户角色或商人角色进行。然后,用户将可以根据角色访问Web应用程序的各个部分。