專案裡要用到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是硬傷啊...)
這些只是我昨天找的一些函式庫,歡迎推薦其他庫麼噠