我在我的node.js应用程序上使用Passport,我正在使用用户名登录。Node.js通过电子邮件或用户名登录策略登录
在我的用户注册页面上,我允许用户注册其唯一的用户名和电子邮件地址。
我想用一个登录页面 “登录使用的用户名/电子邮件:” _ __ _ __ _ _
在哪里,如果有一个 “@” 的脚本可以检测该字段并查找电子邮件而不是用户名。
我已经尝试了几个小时无济于事。
这里是我的passport.js
var mongoose = require('mongoose')
var LocalStrategy = require('passport-local').Strategy
var User = mongoose.model('User');
module.exports = function(passport, config){
passport.serializeUser(function(user, done){
done(null, user.id);
})
passport.deserializeUser(function(id, done) {
User.findOne({ _id: id }, function (err, user) {
done(err, user);
});
});
passport.use(new LocalStrategy({
usernameField: 'username',
passwordField: 'password'
}, function(username, password, done) {
User.isValidUserPassword(username, password, done);
}));
}
编辑:下面是要求
var mongoose = require('mongoose');
var hash = require('../util/hash.js');
UserSchema = mongoose.Schema({
username: String,
email: String,
salt: String,
hash: String
})
UserSchema.statics.signup = function(username, email, password, done){
var User = this;
hash(password, function(err, salt, hash){
if(err) throw err;
// if (err) return done(err);
User.create({
username : username,
email: email,
salt : salt,
hash : hash
}, function(err, user){
if(err) throw err;
// if (err) return done(err);
done(null, user);
});
});
}
UserSchema.statics.isValidUserPassword = function(username, password, done) {
this.findOne({username : username}, function(err, user){
// if(err) throw err;
if(err) return done(err);
if(!user) return done(null, false, { message : 'Incorrect username.' });
hash(password, user.salt, function(err, hash){
if(err) return done(err);
if(hash == user.hash) return done(null, user);
done(null, false, {
message : 'Incorrect password'
});
});
});
};
var User = mongoose.model("User", UserSchema);
module.exports = User;
电子邮件/用户名检测部分在哪里?可能在Mongoose模型中?能够看一看会很有帮助。 – bredikhin
感谢您的回复。我已编辑帖子,以包含user.js – user3081516