0

后端调用

router.post('/exportZip', async function (req, res) {
const source = path.join('./publics/', req.body.id);
const out = './publics/' + req.body.id + '.zip';
const archive = archiver('zip', { zlib: { level: 0 } });
const stream = fs.createWriteStream(out);

return new Promise((resolve, reject) => {
    archive
        .directory(source, false)
        .on('error', err => reject(err))
        .pipe(stream)
        ;

    stream.on('close', () => {
        resolve()
    });
    archive.finalize().then(function () {
        res.status(200).download(path.join(__dirname, '.' + out), function (err) {
            fs.unlink(out, function (err) {
                if (err) console.log(err);
            })
        });

    });
});

});

角度服务

exportSubmissionsAsZip(contest){
    return this.http.post('/exportZip', {id:_id}, {
      responseType: 'arraybuffer',
      headers: new HttpHeaders({ 'Content-Type': 'application/json'})
    });
  }

角度前端

downloadSubmissions(event){
    this.contest.exportSubmissionsAsZip(event).subscribe(res =>{
      console.log(res);
      var blob = new Blob([res], {type: "application/zip"})
      saveAs(blob, event._id+'.zip')
    })
  }

所以当我从我的服务器下载它时,不知何故我得到了损坏的包,

在此处输入图像描述

希望有人可以帮助我解决这个问题,因为到目前为止我所做的改变并不重要。问题保持不变。

更新:

由于某种原因,数组缓冲区比文件本身大

在此处输入图像描述 在此处输入图像描述

响应观察者添加后更新: 在此处输入图像描述

4

0 回答 0