Nadal jestem bardzo nowy dla Node.js i próbuję zrozumieć, jak działają wywołania zwrotne. Tak, tu jest mój problem:Jak zwrócić wartość z zapytania SELECT mysql w pliku node.js
powinny położyć większy mam kod:
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 !'
});
}
})
I komentuje każdą console.log być bardziej jasne. Potrzebuję uzyskać prawidłowy identyfikator kiedy sprawdzić if (!payload.sub)
w app.get()
Czy 'user_id' zmienna' undefined' jeśli 'console.log (user_id)' tuż po ustawieniu go w 'else' rachunku lub gdy używasz go ustawić' payload.sub '? –
dla twojej pierwszej funkcji, '' function fetchID (callback) '' gdzie jest obiekt '' data'' jest przekazywany? –