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