23.03.15 01:43 작성
·
4.2K
14
findOne()도 save()와 마찬가지로 몽구스 5.0부터는 콜백함수를 지원하지 않기 때문에 기존에
app.post('/api/users/login',(req, res) =>{
// 요청된 이메일을 데이터베이스 찾기
User.findOne({email: req.body.email}, (err, docs) =>{
if(!docs){
return res.json({
loginSuccess: false,
messsage: "제공된 이메일에 해당하는 유저가 없습니다."
})
}
// 요청된 이메일이 DB에 있다면 Password가 일치한지 확인
user.comparePassword(req.body.password, (err, isMatch) => {
if(!isMatch)
return res.json({loginSuccess: false, messsage: "비밀번호가 틀렸습니다."})
// Password가 일치하다면 토큰 생성
user.generateToken((err, user)=>{
if(err) return res.status(400).send(err);
// 토큰을 저장
res.cookie("x_auth", user.token)
.status(200)
.json({loginSuccess: true, userId: user._id})
})
})
})
})
에서 콜백함수가 들어가 있기 때문에 callback을 쓰지 않고 promise 또는 async/await로 수정해서 사용하시면 됩니다.
저같은 경우는 promise로 수정해서 .then .catch로 수정을 했습니다.
app.post('/api/users/login',(req, res) =>{
// 요청된 이메일을 데이터베이스 찾기
User.findOne({email: req.body.email})
.then(docs=>{
if(!docs){
return res.json({
loginSuccess: false,
messsage: "제공된 이메일에 해당하는 유저가 없습니다."
})
}
docs.comparePassword(req.body.password, (err, isMatch) => {
if(!isMatch) return res.json({loginSuccess: false, messsage: "비밀번호가 틀렸습니다."})
// Password가 일치하다면 토큰 생성
docs.generateToken((err, user)=>{
if(err) return res.status(400).send(err);
// 토큰을 저장
res.cookie("x_auth", user.token)
.status(200)
.json({loginSuccess: true, userId: user._id})
})
})
})
.catch((err)=>{
return res.status(400).send(err);
})
})
참고하시고 수정하시면 될 것 같습니다.