인프런 커뮤니티 질문&답변

재원님의 프로필 이미지

작성한 질문수

따라하며 배우는 노드, 리액트 시리즈 - 기본 강의

노드 리액트 기초 강의 #12 토큰 생성 with jsonwebtoken

model.findone() no longer accepts a callback 오류

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);
    })
})

참고하시고 수정하시면 될 것 같습니다.

답변 1

0

John Ahn님의 프로필 이미지
John Ahn
지식공유자

2023. 03. 15. 05:03

감사합니다.

재원님의 프로필 이미지

작성한 질문수

질문하기