承诺和代码可读性的节点链



我正试图从节点服务器发送几个请求/响应,因为它们是异步的,所以我不得不深入研究并开始学习promise。Im使用bluebirdnode以及request来发送请求。

我希望建立一个证书链,我的服务器正在充当可信的第三方。我有以下

function send_certificates (addr) {
return send_csr_request(addr)
.then(function(csr) {
return new Promise(function(resolve,reject) {
resolve(sign_device_cert(csr))}
)}).then(function(signed_cert) {
return new Promise(function(resolve,reject) {
//another resolve here?
resolve(send_cert(signed_cert));
})
});
}

理想情况下,我想向这个"承诺链"发出另一个请求,类似于resolve(send_cert(caroot_cert))并且通常能够更好地修改这个请求/响应链。我觉得有很多样板代码就是用来调用这些方法的。还有其他更易于管理和阅读的方法吗?

我也不确定我是否需要承诺所有这些方法?例如,如果sign_device_cert返回Promise,我如何将其与.then()调用链接起来?


编辑

这是我发送请求的函数。。

function send_ca_cert(cert) {
const url_string = "http://myaddress.com";
var request_options = {
url : url_string,
proxy : my_proxy,
body: pki.certificateToPem(cert),
headers: { "someHeader : "somevalue"}
};
return new Promise((resolve,reject) => {
request.postAsync(request_options, function(error, response, body) {
if (!error && response.statusCode == 200) {
console.log("Sent off ca cert" );
resolve();
}
reject();
});
});
}

当我打电话给then(send_cert).then(send_ca_cert)时,我得到了打印

Sent off ca cert
Sent off cert

为什么他们不尊重承诺?

您不必将promise包装在promise中。只做

function send_certificates (addr) {
return send_csr_request(addr)
.then(sign_device_cert)
.then(send_cert);
}

这应该适用于您的情况(至少如果您的代码有效)。

有时,不能只传递原始函数,因为它需要不同的参数(或不同的上下文)。在这种情况下,你仍然可以避免创建一个新的承诺:

return functionReturningAPromise()
.then(otherFunctionReturningAPromise) // takes as parameter the result of the previous one
.then(function(someValue){
return yetAnotherFunctionReturningAPromise(22, someValue);
});

您可以用这种方式编写代码,以提高代码的可读性。

let promise = someAsyncFunction();
promise = promise.then((data) => { // here data is value if returned by function
return someAnotherAsyncCall();
});
promise = promise.then((data) => {// here data is value if returned by the previous function //}
return someAnotherAsyncCall();
});

//同样,你也可以继续!//不要忘记使用箭头函数,它们还有助于提高代码的可读性,并且必须在promise的末尾使用return语句,以避免promise链断裂;

最新更新