Passport.js使用LocalStrategy投掷“undefined不是函数”

时间:2015-08-11 00:28:25

标签: javascript node.js authentication passport.js passport-local

我正在使用Passport.js实现本地身份验证。我已经实现了Github Oauth,这很好,但出于某种原因,本地策略因上述错误而失败。到目前为止,我找不到任何问题的根源。我已阅读其他帖子,但通常的答案是您应将require语句更改为:

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

但是,我已经这样做了。任何帮助将非常感激。这是我的文件。我省略了github策略代码,专注于问题策略:

signin.html:

  <div class="signin-bg">
 <!-- <div class="modal fade" id="login-modal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true" style="display: none;"> -->
<div class="modal-dialog">
   <div class="loginmodal-container">
      <h1>Login using Github</h1><br>
      <a href="/auth/github"><i class="icon-github-sign"></i></a>
      <h3>Or Use your Email</h3>
      <form action="/signin" method="post">
        <input type="text" name="username" placeholder="Email">
        <input type="password" name="password" placeholder="Password">
        <input type="submit" name="login" class="login loginmodal-submit" value="Login">
      </form>
      <div class="login-help">
      <a href="/auth/github">Register</a> - <a href="#">Forgot Password</a>
      </div>
  </div>
</div>

routes.js:

var User = require('./models/userModel');
var passport = require('passport');
var authStore = require('./config/authStore');


module.exports = function(app){

app.get('/signin', function(req, res, next){
  res.render('signin', { message: req.flash('signinMessage') });
});
app.post('/signin', passport.authenticate('local', {
 successRedirect: '/storyBoard',
 failureRedirect: '/signin',
 failureFlash: true
}));

app.get('/signup', function(req, res){
 res.render('signup', { message: req.flash('signupMessage') });
});
app.post('/signup', passport.authenticate('local', {
 successRedirect: '/signin',
 failureRedirect: '/signup',
 failureFlash: true
}));


function isLoggedIn(req, res, next) {
 if(req.isAuthenticated()){
 return next();
}

 res.redirect('/#/signin');
}

};

passport.js

var User = require('../models/userModel.js');
var passport = require('passport');
var GithubStrategy = require('passport-github').Strategy;
var LocalStrategy = require('passport-local').Strategy;
var bcrypt = require('bcrypt');

module.exports = function(passport) {

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

  passport.deserializeUser(function(id, done) {

    User.findUserByGithubId(id, function(err, user) {

      user ? done(null, user) : done(err, null);
    });
  });

  passport.use('local', new LocalStrategy({
    usernameField: 'email',
    passwordField: 'password',
    passReqToCallback: true
  },
  function(req, email, password, done){
    process.nextTick(function(){
      User.findLocalUser(req.email, function(err, user){
        if(err)
          return done(err);
        if(!user)
          return done(null, false, req.flash('signinMessage', 'No user found'));
        if(!User.generateHash(password)){
          return done(null, false, req.flash('signinMessage', 'Invalid password'));
        }
        return done(null, user);
      });
    });
  }
  ));

1 个答案:

答案 0 :(得分:3)

好吧,我不确定你做错了什么,因为你没有粘贴你的所有代码,但这是一个带有护照和连接闪存的快速愚蠢的工作样本,祝你好运。

var express = require('express');
var passport = require('passport');
var LocalStrategy = require('passport-local').Strategy;
var flash = require('connect-flash');
// You need session to use connect flash
var session = require('express-session');
var bodyParser = require('body-parser');

var app = express();

app.use(bodyParser.urlencoded({extended: true}));

app.use( session({
  saveUninitialized : true,
  secret : 'Some Secret' ,
  resave : true,
}));
app.use( passport.initialize());
app.use( passport.session());
app.use(flash());


// Authentication
passport.use(
  new LocalStrategy(
    {},
    function(username, password, done) {

      // Fake user definition, just a sample.
      var user = {name: 'fake', password: 'fake'};

      // Here you can put your async authentication method from db
      if(user.name === username && user.password === password) {
        return done(null, {
          username: username
        });
      }
      else {
        return done(null, false,{});
      }
    })
);

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

passport.deserializeUser( function(user, done) {
  return done(null, user);
});


app.get('/', function(req, res) {

  var htmlToSend = '';

  var error = req.flash('error')[0];

  if(error)
    htmlToSend += '<div style="background-color:red; width:30%;">' + error + '</div>';

  htmlToSend += '<form action="/login" method="post"> \
    <input name="username"/> \
    <input type="password" name="password"/> \
    <button> send \
  </form>';

  res.send(htmlToSend);
});


app.post('/login', passport.authenticate('local', {
  failureRedirect: '/',
  successFlash: 'Welcome!',
  failureFlash: 'User/Password Invalid!'
}),
function(req, res) {
  res.send('Loged In as '+ req.user.username);
});


app.listen(3000, function() {
  console.log('started');
});