我正在使用 Passport js 进行登录注册过程。一旦新人登录,就会在浏览器上创建一个 cookie(由我自定义),其中包含数据库唯一密钥。
那么该程序的工作原理是:
如果新人登录,此函数会创建一个 cookie
function setCookie(cname,cvalue,exdays) {
//alert("Cookie set on tedJavascript");
var d = new Date();
d.setTime(d.getTime() + (exdays*24*60*60*1000));
var expires = "expires="+d.toUTCString();
document.cookie = cname + "=" + cvalue + "; " + expires;
}
然后在登录页面输入的详细信息将发送到服务器上的 post 函数(passport js)。 本地策略认证代码如下(guest、fb等同理)
passport.use('guest',new LocalStrategy(
function(username,password,done){
User.getUserBycookie(password, function(err, user){
if(err) throw err;
//if cookie present (checked in terms of password)
if(user){
//Some code
user.save()
}
else{
console.log("some problem with updating guest user by db id!");
}
});
return done(null, user);
}
//if cookie not present
else {
// some part of code for new user
var newUser = new User();
newUser.guest.cookie = newUser._id;
trophytable_id = newUser._id;
newUser.guest.name = username;
newUser.save(function(err){
if(err) throw err;
return done(null, newUser);
});
}});}));
护照js使用本地、访客、facebook、twitter等策略自动验证信息,如果正确,它会创建会话。
但是,如果已经登录的人进入网站,它首先检查浏览器上是否存在 cookie,如果存在,它会选择 DB key。
知道密钥后,它会从数据库(mongodb)中找到用户的详细信息,并直接跳过登录页面并重定向到主菜单。
但问题是它重定向到主菜单,但无法创建会话,这可能会进一步产生问题所以想再次创建会话,该会话会为新用户自动创建护照。
这是确保经过身份验证的功能
function ensureAuthenticated(req, res, next){
console.log("Inside ensureAuthenticated...............");
if(req.isAuthenticated()){
console.log("Inside if part of ensureAuthenticated-------");
console.log(req.cookies);
return next();
} else {
console.log("Inside else part of ensureAuthenticated----------");
console.log(req.cookies.user_id);
if(isEmpty(req.cookies.user_id)){
console.log("user_id == undefined");
res.redirect('/users/login');
}
else{
console.log("user_id defined");
return next();
}
}
}
next() 导致:
router.get('/',ensureAuthenticated, function(req,res){
console.log("Inside router get ensure authenticated--------------------");
if(isEmpty(req.session.passport)){
//**have to create new session**
//**getting user details from database**
User.getUserBydbid(req.cookies.user_id, function(err, user){
if(err) throw err;
if(user){
if(!isEmpty(user.local)){
//**here i want to create session**
}else if(!isEmpty(user.guest)){
//**here i want to create session**
}
//skipped fb,twitter code
}
else console.log("*********some problem in finding getUserBydbid");
});
//after creating session want to redirect to main menu
//it works but session not created
//res.render('index',{userid:req.cookies.user_id});
}
else{
//for newly logged in user
res.render('index',{userid:req.session.passport.user});
}});
如何为已登录的用户手动创建护照会话?