首頁  >  文章  >  web前端  >  Node批次下載檔案到本地的方法介紹(附程式碼)

Node批次下載檔案到本地的方法介紹(附程式碼)

不言
不言轉載
2019-03-16 10:51:014487瀏覽

這篇文章帶給大家的內容是關於Node批量下載文件到本地的方法介紹(附程式碼),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

多文件分別處理

如果文件數量可控,對於下載出來的文件格式無要求,可以用最簡單的辦法,直接遍歷文件,分別給每個下載連結建立一個單一檔案的download或iframe下載連結。

zip套件批量下載

雖然說可以遍歷所有文件,然後去批量下載單個文件,但是這種體驗畢竟不太好,最常見的做法是把批次的檔案下載並打包到zip中。

所以首先的一個實作想法是:在代理服務裡,先去遍歷所有的文件去請求檔資料,然後壓縮到zip包中,然後再把zip包回傳給客戶端。

這麼做對於下載量資料比較小時ok,但是如果批次檔案特別多特別大時,使用者要等後台把所有的資料都請求到並且都打包都壓縮包裡,前端才能有回饋,這個時間可能會耗時很長,使用者體驗可能很差。

在同事的前期研究時,有說這裡可以做一個流式的邊壓縮邊下載的能力,大致的思路是,chunk回包,加流式壓縮。

......

let fileCounter = 0;
const zippedFilename = encodeURIComponent(downloadData.name);
const list = downloadData.list || [];
const header = {
  'Content-Type': 'application/x-zip',
  'Pragma': 'public',
  'Expires': '0',
  'Cache-Control': 'private, must-revalidate, post-check=0, pre-check=0',
  'Content-disposition': 'attachment; filename="' + zippedFilename + '"',
  'Transfer-Encoding': 'chunked',
  'Content-Transfer-Encoding': 'binary'
};
res.writeHead(200, header);
archive.store = true;
archive.pipe(res);
list.map(item => {
  fileCounter++;
  let inStream = request.get(item.downLoadUrl);
  let name = item.fileName;
  let length = 0;
  inStream.on('response', function(awsData) {
    archive.append(inStream, {
      name: name
    });
  }).on('data', function(data) {
    length += data.length;
  }).on('error', function(e) {
    console.error(name + '-error', e);
  }).on('end', function(endData) {
    fileCounter--;
    if (fileCounter < 1) {
      archive.finalize();
    }
  });
});
archive.on('error', function(err) {
  throw err;
});
archive.on('finish', function(err) {
  return res.end();
});

......

當然中間還有些細節要處理:例如中文檔案名稱的問題,是否需要下載檔案總大小做限制,是否會出現檔案不存在等等情況。

#

以上是Node批次下載檔案到本地的方法介紹(附程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除