SYNCERのロゴ
アイキャッチ画像

Data URIからBlob(File)を作成する方法

JavaScriptで、base64エンコードされたData URIの文字列からBlob(File)を作成する方法を紹介します。例えば、localStorageなどで画像をData URIで保存させて再訪時に取り出す時、Blobに変換して扱えたら何かと便利なことが多いです。

サンプルコード

// 対象の文字列
var dataURI = "..." ;

// "iVBORw..."をバイナリに変換
var byteString = atob( dataURI.split( "," )[1] ) ;

// "image/png"
var mimeType = dataURI.match( /(:)([a-z\/]+)(;)/ )[2] ;

// バイナリからBlobを作成
for( var i=0, l=byteString.length, content=new Uint8Array( l ); l>i; i++ ) {
	content[i] = byteString.charCodeAt( i ) ;
}

var blob = new Blob( [ content ], {
	type: mimeType ,
} ) ;

デモ

ある画像のData URIを、Blobに変換したデモです。

var dataURI = "" ;

var byteString = atob( dataURI.split( "," )[1] ) ;
var mimeType = dataURI.match( /(:)([a-z\/]+)(;)/ )[2] ;

for( var i=0, l=byteString.length, content=new Uint8Array( l ); l>i; i++ ) {
	content[i] = byteString.charCodeAt( i ) ;
}

var blob = new Blob( [ content ], {
	type: mimeType ,
} ) ;

var a = window.URL.createObjectURL( blob ) ;

a =

  • Twitterでシェア
  • Facebookでシェア
  • Google+でシェア
  • はてなブックマークでシェア
  • pocketに保存
  • LINEでシェア
更新履歴
2017年7月29日 (土)
コンテンツを公開しました。