Dropbox 的"filesGetTemporaryLink"抛出一个无法捕获的"UnhandledPromiseRejectionWarning"并终止 Node.js



为了获得Dropbox上托管文件的下载链接,我使用了Dropbox JavaScript API(7.0.0(:

export const fileDownload = async function fileDownload(fileUUID) {
let isSucceeded;
let message;
let file;
const dbx = _dropboxFactory();
try {
const operationResult = await dbx.filesGetTemporaryLink({
path: `/${CONFIG_STORAGE.uploader.assetsPath}/${fileUUID}`
});
if ("OK" === http.STATUS_CODES[operationResult.status].toUpperCase()) {
file = Object.freeze({
length: operationResult?.result?.metadata?.size,
link: operationResult?.result?.link,
mime: mime.lookup(operationResult?.result?.metadata?.name),
name: operationResult?.result?.metadata?.name
});
isSucceeded = true;
message = SYS_MESSAGES.storageFileDownloadSucceeded.code;
} else {
isSucceeded = false;
message = SYS_MESSAGES.storageFileDownloadFailed.code;
}
} catch (err) {
file = "error";
isSucceeded = false;
message = "FIL_NOT_FOUND";
}
const downloadResult = Object.freeze({
file,
isSucceeded,
message
});
return downloadResult;
};

问题是,当文件的path错误时,我会得到一个Node.js异常:

(节点:9156(未处理的PromiseRetentionWarning:#<对象>

(节点:9156(未处理的PromiseRejection警告:未处理的承诺拒绝。此错误源于在没有catch块的情况下抛出async函数内部,或者拒绝未使用.catch()处理的promise。要在未处理的承诺拒绝时终止节点进程,请使用CLI标志--unhandled-rejections=strict(请参阅https://nodejs.org/api/cli.html#cli_unhandled_rejections_mode)。(拒绝id:2(

(节点:9156([DEP0018]不推荐使用警告:不推荐使用未经处理的承诺拒绝。将来,未处理的promise拒绝将使用非零退出代码终止Node.js进程。

我测试了几个选项,得出的结论是问题出在:

const operationResult = await dbx.filesGetTemporaryLink({
path: `/${CONFIG_STORAGE.uploader.assetsPath}/${fileUUID}`
});

我的问题:

  1. 如果生成它的代码被try-catch包装,Node.js为什么要声明«未处理的promise rejection»《未用.catch()处理的promise》并抛出UnhandledPromiseRejectionWarning异常?

  2. 启动Node.js 15.x.x时,未处理的promise拒绝将使用非零退出代码终止Node.js进程。因此,如何避免UnhandledPromiseRejectionWarning

临时解决方法:

运行带有标志--unhandled-rejections=warn的Node.js
这将防止Node.js进程在UnhandledPromiseRejectionWarning时以非零退出代码终止。

这个问题在Dropbox库中,Dropbox团队已经通过发布7.1.0解决了这个问题。升级后,问题中的代码正常工作。

尝试将fileResponse函数更改为类似的函数。您将async/await.then().catch()风格的语法混合在一起。

只需将函数封装在try-catch中即可

async function getDocument() {
try {
const response = await fetch(`${http() + ip}/downloadDocument`, {
body: JSON.stringify({fileUUID: oModel.oData[0].documentFile}),
cache: "no-cache",
credentials: "same-origin",
headers: {
"Content-Type": "application/json"
},
method: "POST",
mode: "cors"
});
const data = await response.json();

return data;
} catch(err) {
console.log(err);
}
}

相关内容

  • 没有找到相关文章

最新更新