Ich verwende eine promise
, um eine Antwort auf Postman der result array
zu erstellen; resolve()
wird jedoch aufgerufen, bevor die forEach-Schleife beendet wird, während resolve()
außerhalb der forEach-Schleife liegt. Ich denke, das liegt an der Callback-Stack-Funktionalität.nodeJS: Promise ausgeführt vor für Schleife beendet, Callback-Stack
Wie führe ich die resolve()
aus, nachdem die forEach-Schleife ausgeführt wurde, unter Berücksichtigung der callback stack
?
(server.js):
logServer.post('/log/asset/audit/', function(req,res){
console.log('--- starting log/asset/audit');
logDB.collection('logs')
.find({"transaction.assetName" : assetName, "transaction.assetOwner" : assetOwner})
.toArray((err, result) => {
let token = JSON.parse(JSON.stringify(self_jwt_body));
var JSONPromise = new Promise((resolve, reject) => { //initialization
result.forEach(function(element, index, array) {
console.log('- before request.post');
request.post({
url: `${dc_link}/audit`, //includes dc_IP, dc_port and /audit
headers: {
"jwt": jwt.sign(token, jwtSecret)
}
}, function(error,response,body) {
console.log('path 0');
let parseBody = JSON.parse(body);
console.log('path 3');
result[0].transaction.signature = parseBody.additionalData;
console.log('result: ', result);
//**HERE
});
});
//**HERE
resolve();
}; //end callback
JSONPromise.then(() => { //finalization //**HERE
respondWithJSON(200, req.body.result, req.body.description, res, result);
console.log('end log/asset/audit');
};
});
});
Sie möchten die Auflösung aufrufen, nachdem alle post() -Aufrufe abgeschlossen wurden? –
Ja, z.B. Nachdem alle Änderungen an result-array vorgenommen wurden, dann resolve() und requestWithJSON aufrufen – computerguy1234
@SLaks Antwort sieht gut aus. –