我已经实现了一个承诺,可以同步完成三个动作。首先,插入数据库并解析该插入的ID。其次,编辑我的json对象,使其包含数据库中最后插入的ID。第三,使用npm请求发送发布请求。这些都包装在一个明确的端点中。
但是,请求调用似乎没有发布到我的API中。我检查了一下,删除了promises依赖项(从数据库中获取最后插入的id是必需的),并使用完全相同的请求结构成功发布了数据。这使我相信 我的诺言有问题。有人可以帮忙吗?
function db() {
return new Promise(function(resolve, reject) {
db.run(`INSERT INTO scan_requests(name, date) VALUES(?,?);`, [req.body.name,req.body.date], function(err) {
if (err) {
console.log(err)
}
let q = this.lastID
resolve(q)
})
})
}
db()
.then(function(q) {
let data = {
url: 'https://api/key/',
body: {
name: req.body.name,
scan_callback: `http://localhost:80/${q}`
},
json: true
}
return(data)
}).then(function(data) {
res.json(req.body)
request
.post(data)
.on('error', function(err) {
console.log(err)
})
.pipe(res)
})
答案 0 :(得分:1)
要链接承诺,解析回调(在then
中执行)需要返回另一个承诺,因此您可以将另一个then
链接到第一个承诺。
就像这样:
function db() {
return new Promise(function (resolve, reject) {
const str = 'Message from first Promise'
resolve(str)
})
}
db()
.then(function (outputFromFirstPromise) {
return new Promise(function (resolve, reject) {
const somethingElse = ', and output from second promise'
const result = outputFromFirstPromise + somethingElse
resolve(result)
})
})
.then(function (outputFromSecondPromise) {
// do something with outputFromSecondPromise
})
在您的情况下,根本不需要中间的承诺。如果没有异步要处理,为什么只使用诺言来构造对象data
?只需将所有内容放入您的第一个承诺的回调中即可。
db().then(function (q) {
let data = {
url: 'https://api/key/',
body: {
name: req.body.name,
scan_callback: `http://localhost:80/${q}`
},
json: true
}
res.json(req.body)
request
.post(data)
.on('error', function (err) {
console.log(err)
})
.pipe(res)
})