【发布时间】:2017-02-03 03:16:48
【问题描述】:
我正在尝试使用 NodeJS 构建登录 API,但我的代码没有达到我的预期。我对 js、promise 和所有东西都很陌生,所以请尽可能简化任何答案。
从我的代码输出中可以看出,第一个承诺部分不会等到函数 findUsers(...) 完成。
我有一个路由文件,我想在其中按顺序运行一些函数:
- 查找用户是否存在于数据库中
- if(1 为真) 对输入的密码进行哈希和加盐
- ...等
路由文件现在包含:
var loginM = require('../models/login');
var loginC = require('../controllers/login');
var Promise = require('promise');
module.exports = function(app) {
app.post('/login/', function(req, res, next) {
var promise = new Promise(function (resolve, reject) {
var rows = loginM.findUser(req.body, res);
if (rows.length > 0) {
console.log("Success");
resolve(rows);
} else {
console.log("Failed");
reject(reason);
}
});
promise.then(function(data) {
return new Promise(function (resolve, reject) {
loginC.doSomething(data);
if (success) {
console.log("Success 2");
resolve(data);
} else {
console.log("Failed 2");
reject(reason);
}
});
}, function (reason) {
console.log("error handler second");
});
});
}
findUser 函数包含池和查询,并且位于模型文件中:
var connection = require('../dbConnection');
var loginC = require('../controllers/login');
function Login() {
var me = this;
var pool = connection.getPool();
me.findUser = function(params, res) {
var username = params.username;
pool.getConnection(function (err, connection) {
console.log("Connection ");
if (err) {
console.log("ERROR 1 ");
res.send({"code": 100, "status": "Error in connection database"});
return;
}
connection.query('select Id, Name, Password from Users ' +
'where Users.Name = ?', [username], function (err, rows) {
connection.release();
if (!err) {
return rows;
} else {
return false;
}
});
//connection.on('error', function (err) {
// res.send({"code": 100, "status": "Error in connection database"});
// return;
//});
});
}
}
module.exports = new Login();
我得到的输出是:
Server listening on port 3000
Something is happening
error handler second
Connection
所以我想知道这段代码有两个方面:
- 为什么第一个 Promise 没有等待
findUser返回才继续执行 if/else,我需要进行哪些更改才能发生这种情况? - 为什么输出的是
error handler second而不是Failed?
我觉得我完全误解了承诺。 我很感激任何答案。谢谢。
【问题讨论】:
标签: javascript mysql node.js express promise