我正在尝试使用Node.js软件开发工具包(https://github.com/dropbox/dropbox-sdk-js)将Excel文件上传到Dropbox。这些文件是从JsReport接收的,保存到我的本地磁盘时会正确保存。但是,当上传到Dropbox时,文件以长字符串结尾,而不是Excel文件。
本例中的主体是一个编码为base64的字符串。文件名为speedtest_daily_2021-01-15_test26.xlsx。
下面这一行成功地将文件写入我的本地驱动器:
fs.writeFileSync(*filename*, body, {encoding: 'base64'});这是我用来上传文件到Dropbox的代码:
body = Buffer.from(body).toString('base64');
dbx.filesUpload({ contents: body, path: saveLocation + `/` + filename })
.then((response: any) => {
console.log(`Saved file "${filename}" to Dropbox folder ${saveLocation}`);
}).catch((uploadErr: DropboxError<files.UploadError>) => {
console.log(uploadErr);
});下面是Excel文件的外观,以及在我的本地计算机上的外观:

这是我打开Dropbox Excel文件时发生的情况:

这是我在文本编辑器中打开Dropbox文件时的样子:

我尝试了Dropbox的各种编码组合,但似乎都不起作用。
发布于 2021-01-16 22:49:24
我想通了。我要做的是将缓冲区发送到filesUpload,而不是编码的字符串。
let buffer = Buffer.from(body, 'base64');
dbx.filesUpload({ contents: buffer, path: saveLocation + `/` + filename })
.then((response: any) => {
console.log(`Saved file "${filename}" to Dropbox folder ${saveLocation}`);
}).catch((uploadErr: DropboxError<files.UploadError>) => {
console.log(uploadErr);
});https://stackoverflow.com/questions/65745774
复制相似问题