18

So I have this webcam feature that returns base64 URI to me and I can't save it to AWS since it needs an image object. Is there any way to convert URI into javascript object?(file object the same as returned by file browser input tag to be exact)

I want to convert this



into this

File {
   lastModified : 1481782908707
   lastModifiedDate : Thu Dec 15 2016 14:21:48 GMT+0800 (Malay Peninsula Standard Time)
   name : "sampleicon2.jpg"
   size :64847
   type : "image/jpeg"
   webkitRelativePath : ""
   __proto__ : File
}

Is it possible? How? Thanks in advance..

1 Answer 1

50

fastest way

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,....', 'filename.png');
console.log(file);
Sign up to request clarification or add additional context in comments.

4 Comments

Wow, you just saved me from lots of trouble. It works perfectly thanks a lot :)
Thanx alot, your answer is saviour for me. @HarelLevy
I am using this code for converting image file but i have got error "cannot read property 1 of null"
mime = arr[0].match(/:(.*?);/)[1], bstr = atob(arr[1]),

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.