gpt4 book ai didi

javascript - 多个异步查询的流程并在完成时运行回调

转载 作者:行者123 更新时间:2023-12-03 12:39:03 24 4
gpt4 key购买 nike

我正在使用 Express.js 创建登录表单。

var status = 0;
req.assert('username', 'Username field is required').notEmpty();
req.assert('password', 'Password field is required').notEmpty();
if (req.validationErrors()) {
res.render('login.html', {title: 'Login form', errors: req.validationErrors()});
}
db.query('SELECT name FROM users WHERE name = ? LIMIT 1', req.body.username, function(errs, data) {
if (errs) {
var errors = [{msg: 'Wrong password / username'}];
res.render('login.html', {title: 'Login form', errors: errors});
}
if (data.length === 0) {
var errors = [{msg: 'Wrong password / username'}];
res.render('login.html', {title: 'Login form', errors: errors});
}
status++;
});
var sha1pw = libs.sha1Crypt(req.body.password);
db.query('SELECT password FROM users WHERE password = ? LIMIT 1', sha1pw, function(errs, data) {
if (errs) {
var errors = [{msg: 'Wrong password / username'}];
res.render('login.html', {title: 'Login form', errors: errors});
}
if (data.length === 0) {
var errors = [{msg: 'Wrong password / username'}];
res.render('login.html', {title: 'Login form', errors: errors});
}
status++;
});

if (status === 2) {
res.send('works');
}

如果用户输入无效的用户名,他们将被重定向到带有错误的登录页面。现在我不知道如何构造它,以便如果两个查询都成功(有数据,良好的用户登录),那么它会发送一条消息。当用户输入正确的密码/用户名组合时,页面将永远保持加载。

最佳答案

使用当前方法,您需要在第一个查询的回调中进行第二个查询:

db.query(sqlForUser, username, function () {
db.query(sqlForPassword, password, function () {
// res.render()
}
}

原因是您当前正在同时运行这两个查询。

但是,我绝不会建议为此任务编写这样的代码。只需将您的查询合并为一个即可:

db.query(
'SELECT name FROM users WHERE name=? AND password=? LIMIT 1;',
[req.body.username, sha1pw],
function () {
if (data.length) {
// success!
} else {
// failure!
}
}
)

关于javascript - 多个异步查询的流程并在完成时运行回调,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23594903/

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