将base64 png数据转换为javascript文件对象

将base64 png数据转换为javascript文件对象,javascript,base64,fileapi,Javascript,Base64,Fileapi,我有两个用PNG编码的base64,我需要使用 我认为最好的方法是使用fileReader将PNG转换为文件对象。我该怎么做呢?您可以从base64数据创建一个Blob,然后将其作为dataurl读取: var img_b64 = canvas.toDataURL('image/png'); var png = img_b64.split(',')[1]; var the_file = new Blob([window.atob(png)], {type: 'image/png', enco

我有两个用PNG编码的
base64
,我需要使用


我认为最好的方法是使用
fileReader
PNG
转换为文件对象。我该怎么做呢?

您可以从base64数据创建一个
Blob
,然后将其作为dataurl读取:

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);
完整示例(包括垃圾代码和控制台日志):


或者,您可以使用
.readAsText
,它工作正常,而且更优雅。。但由于某些原因,文本听起来不正确;)


完整示例:

前面的答案对我不适用

但这很有效。
方式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等)


两者在Chrome和Firefox中都可以使用。

您想比较它们的哪些属性?要了解它们有多相似,您可以在blob上使用FileReader,并且可以从二进制字符串或数组缓冲区中输入blob。这里有一些解决方案。非常好,这应该是公认的答案,它非常简单您可以通过以下方式猜测MIME类型和扩展:```让matches=url.match(/^data:([^;]+);base64,(.*)$/);设mimeType=matches[1];让extension=matches[1].substr(matches[1].indexOf('/')+1)```“方式2”在chrome和firefox上效果很好,但在safari(cordova UIWebview)上停止了为我工作。你的答案真的很有用,我只是想问一下,我们可以进行压缩吗?如果是,请告诉我怎么做。
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);
//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);
})