#javascript #node.js #mongodb #mongoose #passport-local-mongoose
#javascript #node.js #mongodb #мангуст #passport-local-mongoose
Вопрос:
Я хочу зарегистрировать пользователей в своей базе данных MongoDB, используя пакет узла passport-local-mongoose, и у меня с этим нет проблем, но я хочу добавить в базу данных больше, чем имя пользователя и пароль: например (их имена и фамилии, их роли и почти все, что необходимо для пользователь)
как я могу сделать это с помощью passport-local-mongoose, или есть какой-либо другой способ, кроме как с этим пакетом, я уже пытался добавить другие объекты в базу данных, но по какой-то причине это не сработало. вот что я пытался сделать, чтобы получить дополнительные объекты в базе данных:
app.post('/register', function(req, res){
User.register({username: req.body.username}, req.body.password, function(err, user) {
if (err) {
console.log(err);
res.redirect('/register')
} else{
passport.authenticate('local')(req, res, function(){
User.updateOne({ username: req.body.username }, { $set: { firstName: 'firstnName', lastName: 'lastName' } })
res.redirect('/secrets')
})
};
});
})
и, как вы можете видеть, я использовал функцию updateOne от mongoose для установки новых значений вручную, но по какой-то причине я не вижу их в базе данных. а также я содержал имя и фамилию в схеме модели пользователя вот схема:
const userSchema = new mongoose.Schema ({
email: String,
password: String,
firstName: String,
lastName: String
})
есть какие-нибудь предложения?
Ответ №1:
Я нашел ответ, вы должны указать другие значения схемы в поле username объект:
app.post('/register', function(req, res){
User.register({username: req.body.username, firstName: req.body.firstName, lastName:
req.body.lastName}, req.body.password, function(err, user) {
if (err) {
console.log(err);
res.redirect('/register')
} else{
passport.authenticate('local')(req, res, function(){
res.redirect('/secrets')
};
});
})
вы должны изменить схему на эту:
const userSchema = new mongoose.Schema ({
username: String,
password: String,
firstName: String,
lastName: String
})