gpt4 book ai didi

mysql - nodeJS 从回调返回值

转载 作者:可可西里 更新时间:2023-11-01 06:35:50 26 4
gpt4 key购买 nike

我正在构建一个应用程序,在其中进行特定调用时,我必须在继续之前阻止并等待身份验证查询的结果。

function authenticate(userid, hash)
{
mysql_client.query("SELECT `hash` FROM `auth` WHERE `userid` = " + userid, function selectCb(err, results, fields) {
if (err)
{
client.send("Error communicating with mysql, please retry your request");
return false;
}

if(results.length == 0 || results[0].hash != hash)
{
client.send("Error comparing authentication data with database, please retry request");
return false;
}

return true;
}
);
}

我希望能够从 authenticate() 函数本身返回这些值,而不是内部匿名函数 selectCb 并在回调完成之前阻止 authenticate 。我该怎么做呢?

最佳答案

你的外部函数需要自己提供一个回调,一旦 mysql 调用完成就可以执行。类似这样的事情:

function authenticate(user, pass, callback) {
mysql_client.query("...", function (err, results, fields) {
if (err) {
callback("Error communicating ...");
} else if (results.length ...) {
callback("Error comparing authentication...");
}
callback()
});
});

示例用法:

authenticate('jim', '123456', function (err) {
if (err) {
alert(err);
} else {
alert('Welcome');
}
});

关于mysql - nodeJS 从回调返回值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9651046/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com