-
-
Save fupslot/5015897 to your computer and use it in GitHub Desktop.
function dataURItoBlob(dataURI, callback) { | |
// convert base64 to raw binary data held in a string | |
// doesn't handle URLEncoded DataURIs - see SO answer #6850276 for code that does this | |
var byteString = atob(dataURI.split(',')[1]); | |
// separate out the mime component | |
var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0] | |
// write the bytes of the string to an ArrayBuffer | |
var ab = new ArrayBuffer(byteString.length); | |
var ia = new Uint8Array(ab); | |
for (var i = 0; i < byteString.length; i++) { | |
ia[i] = byteString.charCodeAt(i); | |
} | |
// write the ArrayBuffer to a blob, and you're done | |
var bb = new BlobBuilder(); | |
bb.append(ab); | |
return bb.getBlob(mimeString); | |
} |
I believe the BlobBuilder
class is deprecated. Here's a correct representation of the same
function dataURItoBlob(dataURI, callback) {
// convert base64 to raw binary data held in a string
// doesn't handle URLEncoded DataURIs - see SO answer #6850276 for code that does this
var byteString = atob(dataURI.split(',')[1]);
// separate out the mime component
var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0]
// write the bytes of the string to an ArrayBuffer
var ab = new ArrayBuffer(byteString.length);
var ia = new Uint8Array(ab);
for (var i = 0; i < byteString.length; i++) {
ia[i] = byteString.charCodeAt(i);
}
// write the ArrayBuffer to a blob, and you're done
var bb = new Blob([ab]);
return bb;
}
Thanks @dkaranja, it worked well. +1
Where would we define the content type (ex. 'image/png') in the example provided by @dkaranja? I don't see how the mimeString get's reincorporated in the code.
function dataURItoBlob(dataURI, callback) {
// convert base64 to raw binary data held in a string
// doesn't handle URLEncoded DataURIs - see SO answer #6850276 for code that does this
var byteString = atob(dataURI.split(',')[1]);
// separate out the mime component
var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0]
// write the bytes of the string to an ArrayBuffer
var ab = new ArrayBuffer(byteString.length);
var ia = new Uint8Array(ab);
for (var i = 0; i < byteString.length; i++) {
ia[i] = byteString.charCodeAt(i);
}
// write the ArrayBuffer to a blob, and you're done
var bb = new Blob([ab], {type: mimeString});
return bb;
}
thank you, it works @dkaranja
Thanks man!
I am really appreciated effort which you have put in for this solution. Thank you so much.
It's not working in Android 4.2 version OS
thanks. it saved my life time.
You probably wanted to form blob of "Uint8Array" (ia) and ended up using "arrayBuffer" (ab). If not, then what's the use of declaring "ia" in the first place ? It's not being used actively anywhere.
thank you
My example
function dataURIToBlob(dataURI) {
dataURI = dataURI.replace(/^data:/, '');
const type = dataURI.match(/image\/[^;]+/);
const base64 = dataURI.replace(/^[^,]+,/, '');
const arrayBuffer = new ArrayBuffer(base64.length);
const typedArray = new Uint8Array(arrayBuffer);
for (let i = 0; i < base64.length; i++) {
typedArray[i] = base64.charCodeAt(i);
}
return new Blob([arrayBuffer], {type});
}
Life saver! It works great even for pdf or xps or .exe files
thanks a lot @fubslot
Thanks so much :) Tremendous help for me using Expo Image Picker and uploading to Google Storage.
wonderful !
@noonon solution still working. Thanks
thank you
[Error: Creating blobs from 'ArrayBuffer' and 'ArrayBufferView' are not supported]}
Thanks @noonon its working! I would help converting it to TS
function dataURIToBlob(dataURI: string) {
dataURI = dataURI.replace(/^data:/, '');
const type = dataURI.match(/image\/[^;]+/)[0];
const base64 = dataURI.replace(/^[^,]+,/, '');
const arrayBuffer = new ArrayBuffer(base64.length);
const typedArray = new Uint8Array(arrayBuffer);
for (let i = 0; i < base64.length; i++) {
typedArray[i] = base64.charCodeAt(i);
}
return new Blob([arrayBuffer], { type });
}
This is great! thank you @franconisi
saved my life!