項目裡要用到archive和unarchive整個已存在的folder,在找解決方案的時候嘗試了一些當前比較流行的library,主要有adm-zip, JSZip, archiver等。
一.Use adm-zip
adm-zip支援archive和unarchive一個或多個檔案或者整個檔案夾的功能,使用非常的簡單方便。
var adm_zip = require('adm-zip'); //creating archives var zip = new adm_zip(); zip.addLocalFolder('archiver'); zip.writeZip('adm/adm-archive.zip'); //extracting archives var unzip = new adm_zip('adm/adm-archive.zip'); unzip.extractAllTo("adm/adm-unarchive/", /*overwrite*/true);
Pros and cons:
1. 同時實現了壓縮和解壓,而且只要提供路徑就可以對已存在的檔案或檔案夾進行操作,實現了很多介面,使用方便簡單。
2. 本身存在bug,有的時候解壓檔案沒法還原到本來的檔案。Hope慢慢這些bug會fix好。
二. UseJSZip
這個庫在使用的時候需要把檔案一個個增加到zip對象中,而且需要把內容也手動添加,再使用寫檔案操作把記憶體中的zip對象轉成實體儲存體。所以如果是對於一整個檔案夾來說,就很麻煩,需要遍曆檔案夾。
var JSZip = require("jszip");var fs = require("fs");var zip = new JSZip();var file_content = fs.readFileSync('archive/a.txt');zip.file("a.txt",file_content);var data = fs.readFileSync("archive/img/pic.jpeg");zip.file("img/pic.jpeg", data, {base64: true});var zipfolder = zip.generate({type:"nodebuffer"});fs.writeFile("jszip.zip", zipfolder, function(err) { if (err) throw err;});
JSZip裡面也有個folder方法,但它只是用來切換zip對象內部的虛擬路徑,比如zip.folder("img").file('a.txt')就是在zip中添加一個img子目錄,在下面建立a.txt,效果等同於zip.file("img/a.txt")。這裡還需要注意的是,檔案的內容都需要手動添加,如果僅僅是zip.file("a.txt");只是在zip對象中建立了內容為空白的txt檔案,而且它只是存在於記憶體中,需要寫檔案操作後才會真正存到磁碟。
Pros and cons:
1.對於一些即時接受到的資料轉成zip的比較適用。 2.對於已存在的檔案夾操作不便,需要一個個把內容添加到zip對象,再轉成檔案。
3.很多編碼需要注意。
4.只有壓縮功能。
三. Use archiver and unzip
這個組合是最後我使用的,比較靠譜,使用也比較簡單,其中archiver很強大,支援zip格式tar格式,只需要提供路徑就可以壓縮已存在的檔案夾。 壓縮:
var fs = require('fs');var archiver = require('archiver');var output = fs.createWriteStream('archiver-unzip.zip');var archive = archiver('zip');archive.on('error', function(err){ throw err;});archive.pipe(output);archive.bulk([ { src: ['archiver/**']}]);archive.finalize();
解壓:
var fs = require("fs");var unzip = require("unzip");fs.createReadStream('archiver-unzip.zip').pipe(unzip.Extract({ path: 'unarchive' }));
Pros and cons:
1. 久經試用,bug較少。
2.使用方便,不需要遍曆檔案夾。
3. 均只提供壓縮或者解壓,沒有兩個功能都實現的。(所以adm-zip其實很好用,但bug是硬傷啊...)
這些只是我昨天找的一些庫,歡迎推薦其他庫麼麼噠