passport.authenticate 不验证用户

问题描述 投票:0回答:0

我正在尝试使用 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 的新手。

mongoose express-session passport-local mongoose-plugins passport-local-mongoose
© www.soinside.com 2019 - 2024. All rights reserved.