Node.js应用中的多个本地策略不起作用



我正在使用Node.js制作一个web应用程序,该应用程序具有单独的登录和注册两个角色- "user"one_answers";org"。基本流程是:
User
userregistration->userlogindashboard

Org
orgregistration->orgloginorg-dashboard

因为有两个独立的身份验证用例,所以我使用了两个new LocalStrategy实例。

passport.js

module.exports = function (passport) {
passport.use(
"user-local",
new LocalStrategy({ usernameField: "email" }, (email, password, done) => {
User.findOne({ email: email })
.then((user) => {
if (!user) {
return done(null, false, {
message: "That email has not been registered yet!",
});
}
//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));
})
);
passport.use(
"org-local",
new LocalStrategy({ usernameField: "email" }, (email, password, done) => {
Organization.findOne({ email: email })
.then((user) => {
if (!user) {
return done(null, false, {
message: "That NGO has not been registered yet!",
});
}
//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));
})
);
passport.serializeUser((user, done) => {
done(null, { _id: user.id, role: user.role });
});
passport.deserializeUser((login, done) => {
if (login.role === "user") {
User.findById(login, function (err, user) {
if (user) done(null, user);
else done(err, { message: "User not found" });
});
} else if (login.role === "org") {
console.log("here");
Organization.findById(login, (err, user) => {
if (user) done(null, user);
else done(err, { message: "Organization not found" });
});
} else {
done({ message: "No entity found" }, null);
}
});
};

然而,即使用户登录工作正常,我也无法通过orglogin登录。

org.js

//Org Login Handle
router.post("/login", (req, res, next) => {
passport.authenticate('org-local', {
successRedirect: "/org-dashboard",
failureRedirect: "/org/login",
failureFlash: true,
})(req, res, next);
});

user.js

//User Login Handle
router.post('/login', (req,res, next) =>{
passport.authenticate('user-local', {
successRedirect:'/dashboard',
failureRedirect:'/user/login',
failureFlash: true
})(req, res, next);
});

每当我从orglogin登录时,我注意到,它将进入user-local身份验证策略。我是Node.js的新手,我参考了这一点,以便在多个本地策略的情况下获得代码。
请让我知道我必须做任何更改或我需要添加任何其他内容。谢谢。

我能够解决这个问题。表单操作被重定向到userlogin,这就是为什么错误的本地策略被调用。

最新更新