nodeJS从回调中返回值

maj*_*nie 7 mysql callback node.js

我正在构建一个应用程序,在特定的调用中,我必须阻塞并等待来自认证查询的结果才能进行连接.

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;
}
);
}
Run Code Online (Sandbox Code Playgroud)

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

nic*_*ckf 13

你的外部函数需要提供一个回调本身,可以在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()
    });
});
Run Code Online (Sandbox Code Playgroud)

用法示例:

authenticate('jim', '123456', function (err) {
    if (err) {
        alert(err);
    } else {
        alert('Welcome');
    }
}); 
Run Code Online (Sandbox Code Playgroud)