我创建了一个通过电子邮件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)
}
})
}
这将作为承诺解决,auth()
将等待。
你也可以建立search()
作为async/await
承诺。只要你回复诺言决心,它就不会真正得到满足。