Sono ancora molto nuovo su Node.js e sto cercando di capire come funzionano i callback. Così, qui è il mio problema:Come restituire un valore da una query SELECT mysql in node.js
avrei dovuto mettere più codice:
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 !'
});
}
})
ho commentato ogni console.log di essere più chiaro. Ho bisogno di ottenere l'ID corretto quando i check per if (!payload.sub)
in app.get()
E 'la variabile '' user_id' undefined' se 'console.log (user_id)' destra dopo aver impostato nella dichiarazione 'else' o quando lo si usa per impostare' payload.sub '? –
per la tua prima funzione, '' function fetchID (callback) '' dove viene passato l'oggetto '' data''? –