IMG未显示编码为base64字符串的PNG图像



我有一个Apache Cordova应用程序,该应用程序接收了在基本64字符串中编码的PNG图像。

我希望此base64字符串成为IMG标签的来源。

据我所知,我可以定义IMG标签的来源:

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

因此,当应用接收base64字符串时,标签为:

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

如果我将此图像添加到空白的html页面,它将正确显示图像,但是在应用程序中,图像不起作用。

使用以下代码在.NET 4.0中开发的服务器端网络中,将图像编码在base64字符串中:

Convert.ToBase64String(image)

其中图像是字节数组。

我想念什么吗?

这很可能是您的应用程序中的内容安全策略(CSP)问题,浏览器的某些浏览器/版本对浏览器的尊重有所不同,不允许显示Base64编码的图像。

这是我的CSP标头(您也可以执行元标记),它可以对我有效,而它以前不起作用: content-security-policy:default-src 'self'; script-src 'self' ; style-src 'self' 'unsafe-inline' ; img-src * data:; font-src * data:;

这是将图像转换为base64的工作代码。可能是您没有保存图像的格式。

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;
    }
}

此代码如果知道图像类型(JPG),则将图像'previewimage'转换为流,然后转换为base64:

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

最新更新