routes.js
//require the passport strategy from the folder in the project.
var passport = require('passport');
var x = require('./usefile/file');
var requireLogin = passport.authenticate('local',{session: false});
module.exports = function(app){
var auth = express.Router();
app.use('/api/auth', auth);
auth.post('/login', requireLogin, function(req, res){
x.login(req, res)});
}
passport.js
var passport = require('passport');
var JwtStrategy = require('passport-jwt').Strategy;
var ExtractJwt = require('passport-jwt').ExtractJwt;
var LocalStrategy = require('passport-local').Strategy;
var config = require('./auth');
var User = require('../models/user');
var localOptions = {
usernameField: 'email',
};
var localLogin = new LocalStrategy(localOptions, function (email, password, done) {
User.find(
{ email: email }, function (err, user) {
if (err) {
return done(err);
}
if (!user) {
return done(null, false, { error: 'Login failed,Please try again.' });
}
if (!isMatch) {
return done(null, false, { error: 'Login failed, Please try again.' });
}
user.comparePassword(function(password, isMatch){
if(err){
return done(err);
}
if(!isMatch){
return done(null, false, {error:'Login failed, Please try again.'});
}
return done(null, user);
});
});
});
passport.use(localLogin);
注意:我的代码没有使用用于通过护照进行身份验证的requireLogin
,因此它显示400个错误的请求错误。
我在那里找到了护照本地的API文档:
app.post('/login',
passport.authenticate('local', { failureRedirect: '/login' }),
function(req, res) {
res.redirect('/');
});
这里failureRedirect: '/login'
这是什么意思?
请帮忙。
答案 0 :(得分:1)
通过查看您的代码,您的passwordField
声明中似乎没有var localOptions
,我也无法在任何地方看到此localOptions
的使用情况您的代码使用passport.js
根据需要更新代码将使您克服400错误请求错误。
希望这有帮助!
答案 1 :(得分:-1)
检查分号和逗号。还有一些多余的逗号,例如
var localOptions = {
usernameField: 'email',
};
应为:
var localOptions = {
usernameField: 'email'
};