Help us understand the problem. What is going on with this article?

zlibjsのUnzipを使用してブラウザ上でzipファイルを展開する

More than 3 years have passed since last update.

ブラウザで複数ファイルを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

スクリーンショット 2015-12-21 10.04.30.png

解凍

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管理せず利用する方法を考えたところ、当ライブラリに行き着きました。

実際にReactLodashと併用して、コレクション可能なカードをフリーワードで検索できるツールを作成してみました。

ハースストーンカード日本語検索 - jsdo.it

Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
Comments
No comments
Sign up for free and join this conversation.
If you already have a Qiita account
Why do not you register as a user and use Qiita more conveniently?
You need to log in to use this function. Qiita can be used more conveniently after logging in.
You seem to be reading articles frequently this month. Qiita can be used more conveniently after logging in.
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
ユーザーは見つかりませんでした