Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/node.js/39.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript PassportJs,找不到本地策略_Javascript_Node.js - Fatal编程技术网

Javascript PassportJs,找不到本地策略

Javascript PassportJs,找不到本地策略,javascript,node.js,Javascript,Node.js,我不熟悉javascript和node。我遵循passportJS的指南,发现错误“无法找到本地策略”。我不知道为什么。我的代码,基本上是从网站上取下来的 var express = require('express') , routes = require('./routes') , user = require('./routes/user') , http = require('http') , path = require('path') , mongoose = require('mo

我不熟悉javascript和node。我遵循passportJS的指南,发现错误“无法找到本地策略”。我不知道为什么。我的代码,基本上是从网站上取下来的

var express = require('express')
, routes = require('./routes')
, user = require('./routes/user')
, http = require('http')
, path = require('path')
, mongoose = require('mongoose')
, passport = require('passport')
, LocalStrategy = require('passport-local').Strategy;

app.use(passport.initialize());


//to configure the passport
app.use(new LocalStrategy({
usernameField: 'username',
passwordField: 'password'
},
function(username, password, done){
    console.log(username);
    console.log(password);
    People.findOne({username:username},
    function(err, user){
        if(err){return done(err); }
        if(!user){
            return done(null, false, {message:
            'Incorrect username'});
        }
        if(!user.validPassword(password)){
            return done(null, false, {message:
            'Incorrect Password'});
        }
        return done(null, user);
    });
}
));


//route to authenticate the user
app.post('/login',
passport.authenticate('local', { successRedirect:'/accessed',
                                failureRedirect: '/access'})
);
我的错误是“未找到本地策略”,我查看了本地策略模块,找到了定义它的函数。因此,我假设错误在我试图访问该变量的方式中的某个地方

我的服务器设置为

var app = express();

app.configure(function(){
  app.set('port', process.env.PORT || 3000);
  app.set('views', __dirname + '/views');
  app.set('view engine', 'jade');
  app.use(express.favicon());
  app.use(express.logger('dev'));
  app.use(express.bodyParser());
  app.use(express.methodOverride());
  app.use(passport.initialize());
  app.use(app.router);
  app.use(express.static(path.join(__dirname, 'public')));
});

  app.configure('development', function(){
 app.use(express.errorHandler());
});

这是一个使用passport local的样板。中间件的配置顺序很重要。它还实现了代码中似乎缺少的serializeUser/deserializeUser

var express = require('express')
, http = require('http')
, path = require('path')
, passport = require('passport')
, LocalStrategy = require('passport-local').Strategy;

var app = express();

passport.use(new LocalStrategy(function(username, password, done) { 
  // insert your MongoDB check here. For now, just a simple hardcoded check.
  if (username === 'foo' && password === 'bar')
  {
    done(null, { user: username });
  }
  else
  {
    done(null, false);
  }
}));

passport.serializeUser(function(user, done) { 
  // please read the Passport documentation on how to implement this. We're now
  // just serializing the entire 'user' object. It would be more sane to serialize
  // just the unique user-id, so you can retrieve the user object from the database
  // in .deserializeUser().
  done(null, user);
});

passport.deserializeUser(function(user, done) { 
  // Again, read the documentation.
  done(null, user);
});

app.use(express.bodyParser());
app.use(express.cookieParser());
app.use(express.session({ secret: 'secret' }));
app.use(passport.initialize());
app.use(passport.session());

// route to authenticate the user
app.post('/login', passport.authenticate('local', { 
  successRedirect: '/accessed',
  failureRedirect: '/access'
}));

// app.listen(3012);

当您使用curl-v-d“username=foo&password=bar”时http://127.0.0.1:3012/login您将看到您将被重定向到
/accessed
,这意味着身份验证工作正常。

app.use(new LocalStrategy(…)
应该是
passport.use(new LocalStrategy(…))
。我改变了这一点,因为passport.use从未调用过该函数(我在控制台中插入了一个.log)来测试这一点。你能发布你的服务器设置吗?Passport需要加载一组中间件,加载顺序很重要。在app.configure下面我定义了我的mongo数据库在你的包中添加Passport local.json和npm install-dEven我收到了相同的错误。我订购的中间件与上面代码中的相同。“未知身份验证策略”local“”错误的可能原因是什么?@user2235057我认为这取决于如何调用
new LocalStrategy()
。这就是我配置passport的方式<代码>护照。使用({usernameField:'emailAddress'},新的LocalStrategy(函数(用户名、密码、完成){//code here})我在这里发布了一个新问题:。如果你能看一看,那就太好了。