This program demonstrates how to convert a base64 image to an image blob.
<!DOCTYPE html> <html> <head> <title>XoaX.net's Javascript</title> <script type="text/javascript" src="ReadABase64ImageAsABlob.js"></script> </head> <body onload="Initialize()"> <img id="idImage" /><br /> <a id="idDownload">Download</a> </body> </html>
function Initialize() {
const ksBase64Image = '';
const kqBlob = Base64StringToBlob(ksBase64Image, "image/png");
const ksUrl = URL.createObjectURL(kqBlob);
const kqImageElement = document.getElementById("idImage");
kqImageElement.src = ksUrl;
// Make it downloadable
const kqAnchorElement = document.getElementById("idDownload");
kqAnchorElement.href = ksUrl;
kqAnchorElement.download = "XoaxFavIcon.png";
}
function Base64StringToBlob(sBase64, sType) {
// Remove of the starting 'data:image/png;base64,' from the string
const ksBase64Bytes = sBase64.split(",")[1]
// Compress the base 64 encoding to 8 bits per byte, instead of 6
const ksCharBytes = atob(ksBase64Bytes);
// Break the bytes off into chunks for the blob
const ksaaChunks = [];
const kiChunkSize = 1024;
let iByteOffset = 0;
while (iByteOffset < ksCharBytes.length) {
// Brek off the next chunk of character bytes.
const ksaChunk = ksCharBytes.slice(iByteOffset, iByteOffset + kiChunkSize);
// Decode the character chunk into a numerical array
const kaNumbers = new Array(ksaChunk.length);
for (let i = 0; i < ksaChunk.length; ++i) {
kaNumbers[i] = ksaChunk.charCodeAt(i);
}
// Convert to an unsigned integer array
const kuiaUnsignedIntBytes = new Uint8Array(kaNumbers);
ksaaChunks.push(kuiaUnsignedIntBytes);
iByteOffset += kiChunkSize;
}
return new Blob(ksaaChunks, { type: sType });
}© 20072025 XoaX.net LLC. All rights reserved.