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)
| 归档时间: |
|
| 查看次数: |
13161 次 |
| 最近记录: |