nodeJS从回调中返回值

时间:2012-03-10 23:20:27

标签: mysql node.js callback

我正在构建一个应用程序,在这个应用程序中,在特定调用中,我必须阻塞并等待来自身份验证查询的结果。

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,并且在回调完成之前具有验证块。我怎么能这样做呢?

1 个答案:

答案 0 :(得分: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()
    });
});

使用示例:

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