Search code examples
javascriptimagecanvasbase64data-uri

Image to base64 JavaScript


So I'm trying to use the HTML canvas element to take an external image URL and convert it to Base64 so I can extract the colors from it. I'm getting back a base64 string but when I check the output it's blank. Here's my code:

var c = document.getElementById("myCanvas");
    var ctx = c.getContext("2d");
    var img = new Image();
    var imgData
    img.onload = function() {
        ctx.drawImage(img, 0, 0);
    };
    img.src = 'https://cdn.sstatic.net/stackexchange/img/logos/so/so-icon.png';
    imgData = c.toDataURL();
    console.log(imgData)

Is there a better way to approach this?


Solution

  • Another way you can approach this is, you can do a HTTP request and then convert the response to blob. Had a typo, fixed

    I tested this using a local image on my server, and was successful.

    convert = (image, callback) => {
        let request = new XMLHttpRequest();
        request.onload = () => {
            let reader = new FileReader();
            reader.onloadend = () => {
                callback(reader.result);
            };
            reader.readAsDataURL(request.response);
        };
        request.open('GET', image);
        request.responseType = 'blob';
        request.send();
    };
    convert('https://via.placeholder.com/350x150', (base64) => {
        console.log('Base64:', base64)
    })
    

    Output:

    Base64:, 
    

    Make sure you have CORS enabled. Because if CORS is not enabled you will get an error as such:

    Access to XMLHttpRequest at 'https://via.placeholder.com/350x150' from origin 'http://localhost:8000' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.