首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Node.js SDK上载到Dropbox的Excel文件无效

使用Node.js SDK上载到Dropbox的Excel文件无效
EN

Stack Overflow用户
提问于 2021-01-16 09:55:45
回答 1查看 60关注 0票数 0

我正在尝试使用Node.js软件开发工具包(https://github.com/dropbox/dropbox-sdk-js)将Excel文件上传到Dropbox。这些文件是从JsReport接收的,保存到我的本地磁盘时会正确保存。但是,当上传到Dropbox时,文件以长字符串结尾,而不是Excel文件。

本例中的主体是一个编码为base64的字符串。文件名为speedtest_daily_2021-01-15_test26.xlsx

下面这一行成功地将文件写入我的本地驱动器:

代码语言:javascript
复制
fs.writeFileSync(*filename*, body, {encoding: 'base64'});

这是我用来上传文件到Dropbox的代码:

代码语言:javascript
复制
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的各种编码组合,但似乎都不起作用。

EN

回答 1

Stack Overflow用户

发布于 2021-01-16 22:49:24

我想通了。我要做的是将缓冲区发送到filesUpload,而不是编码的字符串。

代码语言:javascript
复制
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);
    });
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65745774

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档