您可以在不重定向的情况下使用Passport进行身份验证吗?

Hyr*_*yra 12 node.js passport-local passport.js

我有以下工作代码通过护照本地策略进行身份验证:

  app.post('/api/login', passport.authenticate('local-login', {
    successRedirect : '/api/login/success',
    failureRedirect : '/api/login/error',
    failureFlash : true
  }));
  app.get('/api/login/error', function(req, res) {
    res.send(401, {error: req.flash('loginMessage')});
  });
  app.get('/api/login/success', function(req, res) {
    res.send(200, {user: req.user});
  });
Run Code Online (Sandbox Code Playgroud)

但是,理想情况下,我希望处理来自一条快速路由的错误和成功消息,而不是重定向到另外两条路由.

这可能吗?我尝试使用'自定义回调',但由于某种原因,似乎在序列化用户时出错.

mag*_*mel 8

您可以使用自定义回调,例如:

passport.authenticate('local', function (err, account) {
    req.logIn(account, function() {
        res.status(err ? 500 : 200).send(err ? err : account);
    });
})(this.req, this.res, this.next);
Run Code Online (Sandbox Code Playgroud)

在错误的对象中,您可以找到在身份验证时出现的所有必需错误.


Clt*_*lto 5

你在使用猫鼬吗?尝试将此添加到server.js/index.js

var User = mongoose.model('User');
passport.use(new LocalStrategy(User.authenticate()));
passport.use(User.createStrategy());
passport.serializeUser(User.serializeUser());
passport.deserializeUser(User.deserializeUser());
Run Code Online (Sandbox Code Playgroud)

这是你的路线index.js

var auth = require('./auth');
app.post('/api/auth/login', passport.authenticate('local'),auth.login);
Run Code Online (Sandbox Code Playgroud)

auth.js:

var UserModel = require('../models/user');
var User = new UserModel();

exports.login = function(req, res) {
    var user = req.user;
    req.login(user, function(err) {
        //if error: do something
        return res.status(200).json(user)
    });
};
Run Code Online (Sandbox Code Playgroud)

将其添加到模型index.js

var passportLocalMongoose = require('passport-local-mongoose');
userSchema.plugin(passportLocalMongoose, {
    usernameField: 'email',
    usernameLowerCase: 'true'
});
Run Code Online (Sandbox Code Playgroud)

我在这里对结构和包做了很多假设.但这应该有效

编辑

对于自定义回调:

app.get('/login', function(req, res, next) {
  passport.authenticate('local', function(err, user, info) {
    if (err) { return next(err); }
    if (!user) { return res.redirect('/login'); }
    req.logIn(user, function(err) {
      if (err) { return next(err); }
      return res.redirect('/users/' + user.username);
    });
  })(req, res, next);
});
Run Code Online (Sandbox Code Playgroud)

在这里你代替res.redirect你可以使用类似的东西return res.status(404).json("Not Found)

有关更多信息,请参阅文档:http://passportjs.org/guide/authenticate/