0

I'm trying to convert base64 to normal image URL using Angular 4. I found the solution:

dataURItoBlob(dataURI)
{
    // convert base64/URLEncoded data component to raw binary data held in a string
    let byteString;
    if (dataURI.split(',')[0].indexOf('base64') >= 0)
        byteString = atob(dataURI.split(',')[1]);
    else
      byteString = unescape(dataURI.split(',')[1]);

    // separate out the mime component
    const mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];

    // write the bytes of the string to a typed array
    const ia = new Uint8Array(byteString.length);

    for (let i = 0; i < byteString.length; i++) {
        ia[i] = byteString.charCodeAt(i);
    }

    return new Blob([ia], {type: mimeString});
}

But the problem is it changes the image URL format to:

".../public/uploads/offers/1531895217034CxqrY.blob"

So I want to change it to normal format PNG or JPG

Bharata
  • 13,509
  • 6
  • 36
  • 50
Damitha
  • 85
  • 1
  • 3
  • 12
  • 2
    check this one https://stackoverflow.com/questions/21227078/convert-base64-to-image-in-javascript-jquery – brk Jul 19 '18 at 07:07

1 Answers1

2

Your function is correct, but after it you have to use URL.createObjectURL() like follows:

function dataURItoBlob(dataURI)
{
    // convert base64/URLEncoded data component to raw binary data held in a string
    var byteString;

    if(dataURI.split(',')[0].indexOf('base64') >= 0)
        byteString = atob(dataURI.split(',')[1]);
    else
        byteString = unescape(dataURI.split(',')[1]);

    // separate out the mime component
    var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];

    // write the bytes of the string to a typed array
    var ia = new Uint8Array(byteString.length);
    for(var i = 0; i < byteString.length; i++)
    {
        ia[i] = byteString.charCodeAt(i);
    }

    return new Blob([ia], {type: mimeString});
}

var dataURI = '';

var blob = dataURItoBlob(dataURI);
var objectURL = URL.createObjectURL(blob);
document.querySelector('input').src = objectURL;
<input type="image" src="#">

Today this will work in Chrome browsers fine, but in IE (and may be some others browsers) you have to check the security policy. Please see in IE the developer console. In this case please read about Cross-origin resource sharing (CORS).

Bharata
  • 13,509
  • 6
  • 36
  • 50
  • @Damitha, which browser do you use? Please check it in Chrome browsers (like Opera too). For IE you have to read the information at the bottom in my answer. – Bharata Jul 19 '18 at 08:40
  • i'm using the Chrome browser – Damitha Jul 19 '18 at 08:49
  • @Damitha, do you see the image after function calling? Please provide more information about why do you write "it's still not working". For example: what do you see in developer console? – Bharata Jul 19 '18 at 08:54
  • this is the code `imageCropped(image: string) { this.croppedImage = image; this.BASE64 = this.dataURItoBlob(image); console.log('BASE64 => ', this.BASE64 ); this.imageData = this.BASE64; } ` **this.imageData** is the variable that i pass through the API – Damitha Jul 19 '18 at 09:06
  • this is the response `BASE64 => Blob(116234) {size: 116234, type: "image/png"} size:116234 type:"image/png" __proto__:Blob` – Damitha Jul 19 '18 at 09:15
  • @Damitha, may be this new code has some mistakes. But in this case you have to ask a new question because I answered your question correctly and my code works. You can not ask 2 different questions in 1 question post according to sites rules. – Bharata Jul 19 '18 at 09:17
  • 1
    @Damitha, if you are satisfied with my answer, please mark it as accepted on the left side from my answer and then write a new question in new post. – Bharata Jul 19 '18 at 09:20