亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

NodeJS:更改密碼期間未處理的承諾拒絕警告

NodeJS:更改密碼期間未處理的承諾拒絕警告

慕桂英546537 2021-12-02 15:43:00
我正在 NodeJS 中更改密碼,但在請求處理過程中出現以下錯誤:(node:16220) UnhandledPromiseRejectionWarning: Error: Can't set headers after they are sent.    at validateHeader (_http_outgoing.js:491:11)    at ServerResponse.setHeader (_http_outgoing.js:498:3)    at ServerResponse.header (/home/pbaj/Documents/Projects/syberiaquotes-backend/node_modules/express/lib/response.js:771:10)    at ServerResponse.send (/home/pbaj/Documents/Projects/syberiaquotes-backend/node_modules/express/lib/response.js:170:12)    at ServerResponse.json (/home/pbaj/Documents/Projects/syberiaquotes-backend/node_modules/express/lib/response.js:267:15)    at user.(anonymous function).updateOne.then.catch.err (/home/pbaj/Documents/Projects/syberiaquotes-backend/api/controllers/user.js:284:52)    at <anonymous>    at process._tickCallback (internal/process/next_tick.js:188:7)(node:16220) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). (rejection id: 1)(node:16220) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.在我的changePassword路線中,我采用email,password,newPassword價值觀和:檢查電子郵件是否存在,如果存在...比較給定的密碼和用戶密碼,如果它們相同...bcrypt.hash 函數采用 newPassword,從中生成哈希值,并保存到 mongoDB如果我提供正確的電子郵件和密碼,上面的所有要點都已完成,但我明白了UnhandledPromiseRejectionWarning。我看到這個問題的原因是在user[0].updateOne(user[0])函數內部,正是在,catch()但我不知道發生了什么。我需要[200]'Password changed!'從我的要求的答案,但我得到[401]'Auth failed'becouse的UnhandledPromiseRejectionWarning。
查看完整描述

2 回答

?
精慕HU

TA貢獻1845條經驗 獲得超8個贊

您發送響應 2 次。試試這個代碼


 if (result) {

            bcrypt.hash(newPassword, 10, (err, hash) => {

                console.log(hash)

                if (err) {

                    return res.status(500).json({

                        error: err

                    })

                } else {

                    user[0].password = hash

                    user[0]

                    .updateOne(user[0])

                    .then(result => {

                        return res.status(200).json({

                            message: 'Password changed!',

                            result: result,

                        })

                    })

                    .catch(err => {

                        res.status(500).json({ message: err.message })

                    })

                }

            })

} else {

          return res.status(401).json({

            message: 'Auth failed'

          })

}


查看完整回答
反對 回復 2021-12-02
?
慕萊塢森

TA貢獻1810條經驗 獲得超4個贊

我假設您使用的是貓鼬(因為User.find(...))。

如果是這樣的話,你不能這樣做user[0].updateOne(...),因為user[0]已經是一個類型的對象User。

您要么執行User.findOneAndUpdate(...),要么user[0].save(...)在設置新密碼后執行(這對我來說似乎更直接)。


查看完整回答
反對 回復 2021-12-02
  • 2 回答
  • 0 關注
  • 305 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號