ブラウザで複数ファイルをxhrで取得したいときや、数メガのファイルを取得したいとき、これらを纏めて1リクエストで済ませたい場合があります。
zlib.jsのUnzipを使用すると、xhrで取得したzipをその場で展開し、直ぐに中のファイルを使用することが出来ます。
ファイル名一覧の取得
zlib-example
tree files
# files
# ├── bar.png
# └── foo.json
zip -r files files
# adding...
上記のような確認用の zipファイル を作成します。
package.json
{
"name": "zlibjs-test",
"dependencies": {
"zlibjs": "^0.2.0"
},
"scripts": {
"start": "beefy index.js --open"
},
"devDependencies": {
"beefy": "^2.1.5"
}
}
上記package.json
を使用して、browserify環境を作成します。
index.js
var Unzip= require('zlibjs/bin/unzip.min').Zlib.Unzip
var url= 'files.zip'
var xhr= new XMLHttpRequest
xhr.open('GET',url,true)
xhr.responseType= 'arraybuffer'
xhr.send()
xhr.addEventListener('load',function(){
var unzip= new Unzip(new Buffer(xhr.response))
var filenames= unzip.getFilenames()
console.log(filenames)
})
unzip.getFilenames
メソッドから、読み込んだzipファイル名の一覧を取得できます。
上記3ファイルを用意すれば、下記のように動作を確認できます。
tree .
# .
# ├── files.zip
# ├── index.js
# └── package.json
npm install
# ...
npm start
# beefy (v2.1.5) is listening on http://127.0.0.1:9966
解凍
unzip.decompress
メソッドに、解凍したいファイル名を指定すると、指定したファイルのUint8Array
を返します。
JSONであれば、下記のようにパースできます。
var Unzip= require('zlibjs/bin/unzip.min').Zlib.Unzip
var url= 'files.zip'
var xhr= new XMLHttpRequest
xhr.open('GET',url,true)
xhr.responseType= 'arraybuffer'
xhr.send()
xhr.addEventListener('load',function(){
var unzip= new Unzip(new Buffer(xhr.response))
var filenames= unzip.getFilenames()
var filename= filenames[2]// foo.json
var buffer= new Buffer(unzip.decompress(filename))
var object= JSON.parse(buffer.toString())
console.log(object)
// {foo: "i am json"}
})
画像であれば、下記のようにdatauri
に変換可能です。
var Unzip= require('zlibjs/bin/unzip.min').Zlib.Unzip
var url= 'files.zip'
var xhr= new XMLHttpRequest
xhr.open('GET',url,true)
xhr.responseType= 'arraybuffer'
xhr.send()
xhr.addEventListener('load',function(){
var unzip= new Unzip(new Buffer(xhr.response))
var filenames= unzip.getFilenames()
var filename= filenames[1]// bar.png
var buffer= new Buffer(unzip.decompress(filename))
var dataURI= 'data:image/png;base64,'+buffer.toString('base64')
console.log(dataURI)
// 
})
さいごに/成果物
ハースストーンの5MB超の翻訳データがjsonで配布されており、これをgit管理せず利用する方法を考えたところ、当ライブラリに行き着きました。