2016-09-30 100 views
0

我检查了这个常见的isue的答案,但它似乎是它的一个个案,我不能找出wth是错误的与我的代码。在这里,我首先设置了本地注册,然后登录,当我尝试登录时,无论输入什么内容,我都会收到“未知策略”本地错误。未知的策略“本地”,nodejs和护照

var express = require("express"); 
    var app = express(); 
    var mysql = require("mysql"); 
    var bodyParser = require("body-parser"); 
    var cookieParser = require("cookie-parser"); 
    var session = require('express-session'); 
    var passport = require('passport'); 
    var LocalStrategy = require('passport-local').Strategy; 

    // expose this function to our app using module.exports 
    module.exports = function(passport) { 
     passport.serializeUser(function(user, done) { 
     done(null, user.id); 
     }); 

     // used to deserialize the user 
     passport.deserializeUser(function(id, done) { 
     connection.query("select * from users where id = "+id,function(err,rows){ 
      done(err, rows[0]); 
     }); 
     }); 

     passport.use('local-signup', new LocalStrategy({ 
      // by default, local strategy uses username and password, we will override with email 
      usernameField : 'email', 
      passwordField : 'password', 
      passReqToCallback : true // allows us to pass back the entire request to the callback 
     }, 
     function(req, email, password, done) { 

      connection.query("select * from users where email = '"+email+"'",function(err,rows){ 
      console.log(rows); 
      console.log("above row object"); 
      if (err) 
        return done(err); 
      if (rows.length) { 
        return done(null, false, req.flash('signupMessage', 'That email is already taken.')); 
       } else { 

      // if there is no user with that email 
        // create the user 
        var newUserMysql = new Object(); 

      newUserMysql.email = email; 
        newUserMysql.password = password; // use the generateHash function in our user model 

      var insertQuery = "INSERT INTO users (email, password) values ('" + email +"','"+ password +"')"; 
       console.log(insertQuery); 
      connection.query(insertQuery,function(err,rows){ 
      newUserMysql.id = rows.insertId; 

      return done(null, newUserMysql); 
      }); 
       } 
     }); 
     })); 

     passport.use('local-login', new LocalStrategy({ 
      // by default, local strategy uses username and password, we will override with email 
      usernameField : 'email', 
      passwordField : 'password', 
      passReqToCallback : true // allows us to pass back the entire request to the callback 
     }, 
     function(req, email, password, done) { // callback with email and password from our form 

      connection.query("SELECT * FROM `users` WHERE `email` = '" + email + "'",function(err,rows){ 
      if (err) 
        return done(err); 
      if (!rows.length) { 
        return done(null, false, req.flash('loginMessage', 'No user found.')); // req.flash is the way to set flashdata using connect-flash 
       } 

      // if the user is found but the password is wrong 
       if (!(rows[0].password == password)) 
        return done(null, false, req.flash('loginMessage', 'Oops! Wrong password.')); // create the loginMessage and save it to session as flashdata 

       // all is well, return successful user 
       return done(null, rows[0]);  

     }); 



     })); 

    } 


    app.use(passport.initialize()); 


    ... 

编辑:忘了写这部分。林与调用它:

app.post('/login', 
    passport.authenticate('local', { successRedirect: '/', 
            failureRedirect: '/login', 
            failureFlash: true }) 
); 
+0

您是否使用护照配置您的策略? – abdulbarik

回答

0

既然你定义的策略为passport.use('local-login', ...),我想你应该在你的端点定义中使用passport.authenticate('local-login')(未示出)。

+0

我忘了写在这里,但是,即时通讯使用passport.authenticate。 – petru

+0

然后,如果将'passport.authenticate('local',...)''改为'passport.authenticate('local-login',...)',它会起作用吗? –