web-dev-qa-db-ja.com

base64 pngデータをjavascriptファイルオブジェクトに変換する

私は2つを持っています base64 PNGでエンコードされているため、 Resemble.JS を使用して比較する必要があります。

それを行う最善の方法は、PNGを使用してfileReaderをファイルオブジェクトに変換することだと思います。どうすればいいですか?

35
Bonik

Base64データからBlobを作成してから、asDataURLを読み取ることができます。

var img_b64 = canvas.toDataURL('image/png');
var png = img_b64.split(',')[1];

var the_file = new Blob([window.atob(png)],  {type: 'image/png', encoding: 'utf-8'});

var fr = new FileReader();
fr.onload = function ( oFREvent ) {
    var v = oFREvent.target.result.split(',')[1]; // encoding is messed up here, so we fix it
    v = atob(v);
    var good_b64 = btoa(decodeURIComponent(escape(v)));
    document.getElementById("uploadPreview").src = "data:image/png;base64," + good_b64;
};
fr.readAsDataURL(the_file);

完全な例(ジャンクコードとコンソールログを含む): http://jsfiddle.net/tTYb8/


または、.readAsTextを使用することもできます。これは正常に機能し、よりエレガントです。しかし、何らかの理由でtextは正しく聞こえません;)

fr.onload = function ( oFREvent ) {
    document.getElementById("uploadPreview").src = "data:image/png;base64,"
    + btoa(oFREvent.target.result);
};
fr.readAsText(the_file, "utf-8"); // its important to specify encoding here

完全な例: http://jsfiddle.net/tTYb8/3/

34
c69

ウェイ1:dataURLでのみ機能し、他のタイプのURLでは機能しません。

function dataURLtoFile(dataurl, filename) {
    var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
        bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
    while(n--){
        u8arr[n] = bstr.charCodeAt(n);
    }
    return new File([u8arr], filename, {type:mime});
}

//Usage example:
var file = dataURLtoFile('data:image/png;base64,......', 'a.png');
console.log(file);

ウェイ2:あらゆるタイプのURLで機能します(http url、dataURL、blobURLなど)

//return a promise that resolves with a File instance
function urltoFile(url, filename, mimeType){
    mimeType = mimeType || (url.match(/^data:([^;]+);/)||'')[1];
    return (fetch(url)
        .then(function(res){return res.arrayBuffer();})
        .then(function(buf){return new File([buf], filename, {type:mimeType});})
    );
}

//Usage example:
urltoFile('data:image/png;base64,......', 'a.png')
.then(function(file){
    console.log(file);
})

両方ともChromeおよびFirefoxで動作します。

45
cuixiping

前の答えは私にはうまくいきませんでした。

しかし、これは完全に機能しました。 データURIをファイルに変換してからFormDataに追加

4
love2code