我做了一个通过电子邮件ID搜索用户的功能。我正在使用await在异步函数中调用该函数,并将返回值分配给或常量/变量,但在打印常量/变量时变得不确定

function search(email) {
    sql = `SELECT email FROM users WHERE email = '${email}'`;
    db.query(sql, (err, res) => {
        if (err) {
            console.log(err);
        }
        else {
            return res[0].email;
        }
    })
}

const auth = async (req, res, next) => {
    try {
        const token = req.header('Authorization').replace('Bearer', '');
        const decoded = jwt.verify(token, 'catisdoguniversaltruth');
        const user = await search(decoded._id);
        console.log(user);
        if (!user) {
            throw new Error();
        }
        next();
    }
    catch (e) {
        res.status(401).send("Not Authenticated, Please login");
    }
};

module.exports = auth;

最佳答案

您需要search()是一个承诺而不是一个功能。

await等待诺言解决。

尝试这个:

 function search(email){
   return new Promise((resolve, reject) => {
     sql = `SELECT email FROM users WHERE email = '${email}'`
     db.query(sql, (err, res)=>{
     if(err){
       reject(err);
     }
     else{
       resolve(res[0].email)
     }
   })
 }



这将作为promise解决,auth()将等待。

您也可以按search()的承诺构建async/await。只要您返回承诺解决方案,就不会真正感到困惑。

关于javascript - 为什么即使在异步功能中使用时,等待也无法正常工作,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/55220486/

10-14 22:56
查看更多