我正在尝试使用 passport-local 和 passport-local-mongoose 注册和验证用户,但用户未通过身份验证。 我不想降级我的猫鼬版本。
这是用于注册和验证用户以重定向到“/secrets”路由的代码。用户已在 MongoDB 数据库中成功注册,但未通过身份验证。
app.post('/register',function(req,res,next){
User.register({username:req.body.username},req.body.password)
.then((user) =>{
passport.authenticate("local",function(err,user,info){
if(!err)
{
res.redirect("/secrets");
}
else{
console.log(err);
}
})(req,res,next);
})
.catch(err =>{
console.log(err);
res.redirect("/register");
});
});
下面的代码没有任何错误地执行,但是用户没有通过身份验证并且被重定向到“/登录”路由而不是显示“秘密”页面。
passport.authenticate("local",function(err,user,info){
if(!err)
{
res.redirect("/secrets");
}
else{
console.log(err);
}
})(req,res,next);
这是“/秘密”路线:
app.get('/secrets',function(req,res){
if(req.isAuthenticated())
{
res.render("secrets");
}
else
{
res.redirect("/login");
}
});
这是完整的代码:
require("dotenv").config();
const express = require('express');
const bodyParser = require('body-parser');
const ejs = require("ejs");
const mongoose = require("mongoose");
const session = require("express-session");
const passport = require("passport");
const passportLocalMongoose = require("passport-local-mongoose");
const app = express();
app.use(express.static("public"));
app.use(bodyParser.urlencoded({extended:true}));
app.set("view engine",'ejs');
app.use(session({
secret: 'Our Little Secret',
resave: false,
saveUninitialized: false
}));
app.use(passport.initialize());
app.use(passport.session());
mongoose.connect("mongodb://127.0.0.1:27017/userDB");
const userSchema = new mongoose.Schema({
email:String,
password: String
});
userSchema.plugin(passportLocalMongoose);
const User = new mongoose.model("User",userSchema);
passport.use(User.createStrategy());
passport.serializeUser(User.serializeUser());
passport.deserializeUser(User.deserializeUser());
app.get('/',function(req,res){
res.render('home');
});
app.get('/login',function(req,res){
res.render('login');
});
app.get('/register',function(req,res){
res.render('register');
});
app.get('/secrets',function(req,res){
if(req.isAuthenticated())
{
res.render("secrets");
}
else
{
res.redirect("/login");
}
});
app.post('/register',function(req,res,next){
User.register({username:req.body.username},req.body.password)
.then((user) =>{
passport.authenticate("local",function(err,user,info){
if(!err)
{
res.redirect("/secrets");
}
else{
console.log(err);
}
})(req,res,next);
})
.catch(err =>{
console.log(err);
res.redirect("/register");
});
});
app.post('/login',function(req,res){
});
app.listen(3000,function(){
console.log('server running on port 3000... ');
});
请帮忙,我是 Node.js 和 Mongoose 的新手。