javascript - 无法使用 Passport 登录 - Nodejs

标签 javascript node.js mongoose passport.js

我正在遵循 Udemy 教程之一,但我陷入了登录过程的最后一步。我可以注册新用户但无法登录。我输入电子邮件地址和密码。在按下提交按钮时,无论电子邮件地址或密码的值正确还是错误,它都会触发 Passport 的 failureRedirect 方法,该方法再次拉出登录页面,我已经放置了几个 console.logs,但没有一个打印在控制台中。此外,如果输入任何随机细节,它应该抛出未知的用户错误。我不确定是什么导致它无法工作,在控制台或浏览器中没有看到或发现错误。

表单-login.ejs

<form class="form-signin" action="/login" method="POST">
        <h2 class="form-signin-heading">Please sign in</h2>
        <label for="inputEmail" class="sr-only">Email address</label>
        <input type="email" id="email" name="email" class="form-control" placeholder="Email address" required autofocus>
        <label for="inputPassword" class="sr-only">Password</label>
        <input type="password" id="password" name="password" class="form-control" placeholder="Password" required>
       <button class="btn btn-lg btn-primary btn-block" type="submit">Sign in</button>
</form>

路线-index.js

var express = require('express');
var router = express.Router();
var passport = require('passport');
var LocalStrategy = require('passport-local').Strategy;

var User = require('../models/user');
router.get('/login', function(req, res, next) {
  res.render('login', { title: 'login', errors: false });
});


passport.serializeUser(function(user, done) {
  done(null, user.id);
});

passport.deserializeUser(function(id, done) {
  User.getUserById(id, function(err, user) {
    done(err, user);
  });
});

passport.use(new LocalStrategy(
    function (email, password, done){ 
        console.log("testing... 1");
        User.getUserByEmail(email, function(err, user){
            if (err) throw err;
            if(!user){
                console.log('Unknown User');
                console.log("testing... 3");
                return done(null, false, {message: 'Unknown User'});
            }

            User.comparePassword(password, user.password, function(err, isMatch){
                console.log("testing... 2");
                if(err) throw err;
                if (isMatch){
                    return done(null, user);
                    console.log("testing... 4");
                }else{
                    console.log("Invalid Password");
                    return done(null,false, {message:'Invalid Password'});
                }
            });
        });
    }
));


router.post('/login', passport.authenticate('local', {failureRedirect: '/login', failureFlash: 'Invalid username or password'}), function(req, res) {

    console.log('Authentication successful');
    //Flash message
    req.flash('success','Your credentials match redirecting...');
    //Redirect to the dashboard page
    res.location('/dashboard');
    res.redirect ('/dashboard');

});

模型 - user.js

var mongoose = require('mongoose');
var bcrypt = require('bcrypt');
mongoose.connect('mongodb://localhost/db_name');
var db = mongoose.connection;

//User Schema

var UserSchema = mongoose.Schema({
    name:{
        type: String,
        index:true
    },
    email:{
        type:String
    },
    password:{
        type:String, required:true, bcrypt:true
    }
});

var User = module.exports = mongoose.model('User', UserSchema);

module.exports.comparePassword = function(candidatePassword, hash, callback){
    bcrypt.compare(candidatePassword, hash, function(err, isMatch){
        if(err) return callback(err);
        callback(null, isMatch);

    });
}

module.exports.getUserByEmail = function(email, callback){
    var query = {email:email};
    User.findOne(query, callback);
}

module.exports.getUserById = function(id, callback){
    User.findById(id, callback);
}

mongodb - 用户集合对象

db.users.find().pretty();
{
        "_id" : ObjectId("594c330d520d491b18771425"),
        "name" : "John Doe",
        "email" : "john@gmail.com",
        "password" : "$2a$10$aFt9vfsSVJpFA8CMlCYIaOqQjW.6lV/1i0PibLelC43HscaAIvQPW",
        "__v" : 0
}

最佳答案

passport.serializeUser(function(user, done) {
  done(null, user.id);
});
passport.deserializeUser(function(user, done) {
  User.getUserById(id, function(err, user) {
  done(err, user);
 });
});

如果我们序列化用户对象,那么反序列化用户对象而不仅仅是 ID

请查看 https://github.com/rupalipemare/Mongoose-Demo 上的示例,其中有完整的示例演示 Passport 认证。

关于javascript - 无法使用 Passport 登录 - Nodejs,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44715944/

相关文章:

javascript - 为什么我的 js.erb 文件中没有工作链接

javascript - 图像 slider 的响应式设计不符合预期

javascript - 在IE11中将其删除后调用的事件监听器函数

javascript - 将 async/await 与 for 循环一起用于嵌套的 Axios 调用

node.js - Yeoman Web 应用程序中没有/bower_components/

mongodb - 在一个 MongoDB 聚合查询中进行排序和分组

node.js - Mongoose 一次插入多条相关记录

javascript - jQuery append/prepend in loop - 当所有元素应该一一显示时,它们一起出现

javascript - Node JS 同步事件

node.js - NodeJS mockgoose 保存模型似乎不起作用