战略没有被使用,为什么?

时间:2016-03-02 07:36:13

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

我是快递新手,我试图用护照实施一些身份验证方法。对我来说这似乎是最好的选择,我开始阅读几个教程,现在我有这个不寻常的代码。 显然,未使用策略 registerStrategy ,因为 console.log(" log"); 未显示在服务器的控制台中。 节点不会抛出任何错误。



//localStrategy.js

var registerStrategy = new localStrategy(
  function(req, res, done){
    console.log("log");
    var user = {
      username: req.user.username,
      password: req.user.password,
      name: req.body.user.name,
      lastname: req.body.user.lastname,
      email: req.body.user.email,
      event_time: req.body.user.event_time
    };
    var usernameExists = true, emailExists = true;
    var tasks = [
      function(cb){
        db.usernameExists(user.username, function(err, exists){
          if(err) return cb(err);
          usernameExists = exists;
          cb();
        });
      },
      function(cb){
        db.emailExists(user.email, function(err, exists){
          if(err) return cb(err);
          emailExists = exists;
          cb();
        });
      }
    ];
    async.parallel(tasks, function(err){
      if(err) return done(err);
      if(usernameExists || emailExists){
        return done(null, usernameExists, emailExists);
      }
      done(null, null, null);
    });

  }
);
	
	app.use(session(sessionData));
	passport.use("local-register", registerStrategy);

//routes.js

app.post("/api/register", function(req, res){
  passport.authenticate("local-register")(req, res, 
                                          function(err, usernameExists, emailExists){
    if(err) throw err;
    if(usernameExists){
      return res.status(401).json({ err: "User exists"});
    }
    else if(emailExists){
      return res.status(401).json({ err: "Email exists"});
    }
    res.status(200).json({status: "Succesful"});
  }
  );
});




我的错误在哪里?

1 个答案:

答案 0 :(得分:0)

passport.authenticate(...)是一个返回middleware函数的函数,因此第三个参数是对下一个middleware函数的引用。在你的代码中匿名函数:

function(err, usernameExists, emailExists){
    if(err) throw err;
    if(usernameExists){
      return res.status(401).json({ err: "User exists"});
    }
    else if(emailExists){
      return res.status(401).json({ err: "Email exists"});
    }
    res.status(200).json({status: "Succesful"});
})

应该在passport.authenticate函数中作为callback。像这样:

app.post("/api/register", function(req, res){
  passport.authenticate("local-register", function(err, usernameExists, emailExists){
    if(err) throw err;
    if(usernameExists){
      return res.status(401).json({ err: "User exists"});
    }
    else if(emailExists){
      return res.status(401).json({ err: "Email exists"});
    }
    res.status(200).json({status: "Succesful"});
  })(req, res);
});

另请注意,匿名函数的第二个参数应该是应用程序在有机会验证凭据(用户对象)后提供的对象,第三个参数是有关用户的其他信息。关于LocalStrategy中的代码,为了在参数中传递req对象,您需要指定选项{passReqToCallback : true},之后在函数callback中将有四个参数是requsernamepassword和另一个callback函数,通常名为done,因此签名应该是这样的:

var registerStrategy = new localStrategy(
    {passReqToCallback : true},
    function(req, username, password, done){
        ...
    }