为了获得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}`
});
我的问题:
如果生成它的代码被
try-catch
包装,Node.js为什么要声明«未处理的promise rejection»或《未用.catch()
处理的promise》并抛出UnhandledPromiseRejectionWarning
异常?启动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);
}
}