IMG not showing a PNG image encoded as a Base64 string

5.6k views Asked by At

I have an Apache Cordova application that receives a PNG image encoded in a Base64 string.

I want this Base64 string to be the source of an IMG tag.

As far as I know, I can define the source of an IMG tag as follows:

<img style="display:block;" src="_ENCODED_IMAGEā€/>

So when the app receives the Base64 string the tag is:

<img style="display:block;" src="" />

If I add this Image to a blank HTML page it shows the image correctly, but in the app the image is not working.

The Image is encoded in a Base64 string by a server side Webservice developed in .NET 4.0 using the following code:

Convert.ToBase64String(image)

Where image is a byte array.

Am I missing something?

3

There are 3 answers

0
vinkiss On

This is the working code to convert an image to base64. Might be you are not saving the format of an image.

public string ImageToBase64(Image image, System.Drawing.Imaging.ImageFormat format)
{
    using (MemoryStream ms = new MemoryStream())
    {
    // Convert Image to byte[]
    image.Save(ms, format);
    byte[] imageBytes = ms.ToArray();

    // Convert byte[] to Base64 String
    string base64String = Convert.ToBase64String(imageBytes);
    return base64String;
    }
}
0
codestever On

This code converts an image 'previewImage' to a stream before converting to base64 if you know the image type (jpg):

        var imageStream = new MemoryStream();
        previewImage.Save(imageStream, ImageFormat.Jpeg);
        var base64ImageString = "data:image/jpg;base64,"
            + Convert.ToBase64String(imageStream.ToArray(), 0, imageStream.ToArray().Length);
0
Matty J On

This could well be a Content Security Policy (CSP) issue in your app, which some browsers / versions of browser respect differently, not allowing the base64 encoded image to be displayed.

This is my CSP header (you can do a meta-tag too) that allows it to work for me, when it didn't work before: content-security-policy:default-src 'self'; script-src 'self' ; style-src 'self' 'unsafe-inline' ; img-src * data:; font-src * data:;