Tôi vẫn còn rất mới đối với Node.js và tôi đang cố gắng hiểu cách gọi lại hoạt động. Vì vậy, đây là vấn đề của tôi:Cách trả về một giá trị từ truy vấn SELECT mysql trong node.js
tôi nên đã đặt mã hơn:
POST:
app.post('/register', function(req, res) {
//get data from the request
var data = {
username: req.body.username,
email: req.body.email,
password: req.body.password
};
function fetchID(callback) {
connection.query('SELECT id_user FROM USERS WHERE username = ?', data.username, function(err, rows) {
if (err) {
callback(err, null);
} else
callback(null, rows[0].id_user);
});
}
var user_id;
fetchID(function(err, content) {
if (err) {
console.log(err);
return next("Mysql error, check your query");
} else {
user_id = content;
console.log(user_id); //undefined
}
});
console.log(user_id); //undefined
var payload = {
iss: req.hostname,
sub: user_id
}
console.log(payload.sub); //correct id
})
GET:
app.get('/todos', function(req, res) {
if (!req.headers.authorization) {
return res.status(401).send({
message: 'You are not authorized !'
});
}
var token = req.headers.authorization.split(' ')[1];
var payload = jwt.decode(token, "shhh..");
//additional level of security
console.log('sub id is : ' + payload.sub); //undefined
if (!payload.sub) {
return res.status(401).send({
message: 'Authentication failed !'
});
}
})
tôi nhận xét mỗi console.log được rõ ràng hơn. Tôi cần phải nhận được id chính xác khi tôi kiểm tra cho if (!payload.sub)
trong app.get()
là 'cái user_id' biến' undefined' nếu bạn 'console.log (user_id)' ngay sau khi đặt nó trong 'tuyên bố else' hoặc khi bạn đang sử dụng nó để thiết lập 'payload.sub '? –
cho hàm đầu tiên của bạn, hàm 'fetchID (gọi lại)' 'ở đâu là đối tượng' 'data'' đang được truyền? –