如何在HTML中显示Base64图像

1131
我在尝试将一个Base64编码的图片内联显示时遇到了问题。
有什么办法可以解决吗?
<!DOCTYPE html>
<html>
  <head>
    <title>Display Image</title>
  </head>
  <body>
    <img style='display:block; width:100px;height:100px;' id='base64image'
       src='data:image/jpeg;base64, LzlqLzRBQ... <!-- Base64 data -->' />
  </body>
</html>

4
这是一个关于HTTP基础和数据URI的文章,它介绍了如何使用数据URI来将小型数据嵌入到网页中,以及如何解码数据URI。数据URI是一种允许在网页中直接嵌入小型数据的方式,这样可以减少HTTP请求次数并提高网页性能。数据URI以"data:"开头,后面跟着MIME类型和编码的数据内容。在使用数据URI时,需要注意编码和字符集问题,并且要注意数据大小对性能的影响。 - Christophe Roussy
22
阅读此问题及其答案的任何人...请考虑您是否真正需要base64编码。 在现代浏览器中几乎从不需要它。 如果您使用base64编码,那么会将图像大小增加33%的开销,在编码和解码时需要额外的CPU和内存,向DOM添加不必要的额外数据,并对大小和资源类型施加严格而不一致的限制。 相反,请使用blob、对象URL等技术。 - Brad
18
@Brad,有时候当你需要事物是自包含的时,Base64 是唯一的选择。实际上,我在尝试编写一个脚本来从 Jupyter 笔记本中提取图像(它们保存为 Base64 PNG 格式),并将其转换成一个 HTML 文件以发布为报告时,偶然发现了这个页面。 - vikarjramun
3
@Brad,我现在做的事情肯定有更好的方法,但是我很懒,现在也不关心呈现方式,因为这只是用来发送给我的同事讨论的。此外,有谁不喜欢编写复杂的Shell单行命令来完成任务呢? :) - vikarjramun
5
@StuartAitken 不,那是明显错误的。我们已经拥有对象URL将近十年了。请阅读此文档,并回去告诉任何告诉你这是适当使用base64的人,传达好消息:在这种情况下不需要使用base64。 - Brad
显示剩余14条评论
14个回答

1674

我怀疑的当然是实际的Base64数据。除此之外,对我来说看起来挺好的。在这个this fiddle上看到一个类似的方案正在运作。你可以尝试指定字符集。

<div>
  <p>Taken from wikpedia</p>
  <img src="data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAAAUA
    AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
        9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot" />
</div>

你可以尝试使用这个Base64解码器来查看你的Base64数据是否正确。

感谢您抽出时间回答我的问题...那个JS Fiddle只是输出了一个红点?这就是它的意图吗? - Christopher
3
我相信我已经发现了问题所在,即每次上传base64文件时,每个"+"符号似乎都被移除了,这会导致jpeg文件无效。我正在使用AJAX将图像从设备上传到服务器,是否有可能因为它是一个HTML实体,所以无法正确传递"+"号? - Christopher
7
@Christopher,“+”字符在提交数据时可能会出现问题。请参考相关的SO问题:https://dev59.com/mnM_5IYBdhLWcg3wcSx_,进行处理。 - VinayC
1
刚刚使用了上面问题中的HTML,并加入了一些有效的base64数据作为PNG,它可以正常工作...这就是正确的答案。 - Benjamin Conant
这是最佳实践吗? - Lasantha Basnayake
显示剩余6条评论

151

您需要指定正确的内容类型(Content-type)内容编码(Content-encoding)字符集(charset)

例如:

 data:image/jpeg;charset=utf-8;base64,

根据数据URI方案的语法
 data:[<media type>][;charset=<character set>][;base64],<data>

1
https://dev59.com/02Yr5IYBdhLWcg3w8-kz 表明没有用 base-64 编码 HTTP 正文的头。 - Dan Dascalescu
1
此外,https://dev59.com/0Gw05IYBdhLWcg3wXQog - 这是一个MIME头,而不是HTTP头。您能详细说明应该如何指定内容编码吗? - Dan Dascalescu
5
这对我解决了问题。Chrome会假定UTF-8并显示图片,而Microsoft Edge则无法渲染。一旦我包含了字符集,图片就完美显示了。 - Altimus Prime
能否使用 input 代替 img?我想在标签或文本框中显示值,而不是图像。 - Dr.jacky

67

首先将您的图像转换为Base64格式(编码为Base64)。您可以在线或使用PHP脚本进行转换。

转换后,您将得到以下结果

iVBORw0KGgoAAAANSUhEUgAAABkAAAAZCAYAAADE6YVjAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MEVBMTczNDg3QzA5MTFFNjk3ODM5NjQyRjE2RjA3QTkiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MEVBMTczNDk3QzA5MTFFNjk3ODM5NjQyRjE2RjA3QTkiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDowRUExNzM0NjdDMDkxMUU2OTc4Mzk2NDJGMTZGMDdBOSIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDowRUExNzM0NzdDMDkxMUU2OTc4Mzk2NDJGMTZGMDdBOSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PjjUmssAAAGASURBVHjatJaxTsMwEIbpIzDA6FaMMPYJkDKzVYU+QFeEGPIKfYU8AETkCYI6wANkZQwIKRNDB1hA0Jrf0rk6WXZ8BvWkb4kv99vn89kDrfVexBSYgVNwDA7AN+jAK3gEd+AlGMGIBFDgFvzouK3JV/lihQTOwLtOtw9wIRG5pJn91Tbgqk9kSk7GViADrTD4HCyZ0NQnomi51sb0fUyCMQEbp2WpU67IjfNjwcYyoUDhjJVcZBjYBy40j4wXgaobWoe8Z6Y80CJBwFpunepIzt2AUgFjtXXshNXjVmMh+K+zzp/CMs0CqeuzrxSRpbOKfdCkiMTS1VBQ41uxMyQR2qbrXiiwYN3ACh1FDmsdK2Eu4J6Tlo31dYVtCY88h5ELZIJJ+IRMzBHfyJINrigNkt5VsRiub9nXICdsYyVd2NcVvA3ScE5t2rb5JuEeyZnAhmLt9NK63vX1O5Pe8XaPSuGq1uTrfUgMEp9EJ+CQvr+BJ/AAKvAcCiAR+bf9CjAAluzmdX4AEIIAAAAASUVORK5CYII=

现在使用起来非常简单。

你只需将其放入图像的src中,并将其定义为Base64编码形式。

示例:

<img src="">

4
一个解决iOS UIWebView缓存问题的绝佳方案,即使我删除了图像文件,它仍然会引用旧的图像数据。这个答案帮助我避免了创建唯一文件名并在之后进行清理的麻烦。谢谢@NARGIS PARWEEN。 - Ed of the Mountain
这是一个被编码为字符串的图像吗?每个图像都可以表示为字符串吗?图像具有的细节越多,字符串就越长? - Timo
3
@Timo 是的(这里用“base64”),是的(我相信任何数据都可以进行字符串编码),而且是的(数据越多,字符就越多)。 - Mtxz
使用PowerShell将图像文件转换为base64:https://deangrant.me/2014/10/01/encoding-image-files-into-a-base64-string-using-powershell/ - Matthew Lock

56

如果你的后端有PHP,你可以使用这段代码:

$image = 'http://images.itracki.com/2011/06/favicon.png';
// Read image path, convert to base64 encoding
$imageData = base64_encode(file_get_contents($image));

// Format the image SRC:  data:{mime};base64,{data};
$src = 'data: ' . mime_content_type($image) . ';base64,' . $imageData;

// Echo out a sample image
echo '<img src="' . $src . '">';

26

这将显示一个Base64数据的图像:

<style>
    .logo {
        width: 290px;
        height: 63px;
        background: url(-paste-Base64-data-here) no-repeat;
    }
</style>

<div class="logo"></div>

我认为这需要解释一下它如何回答这个问题。请通过编辑(更改)您的答案来回应,而不是在评论中回应(不要包含“编辑:”,“更新:”或类似内容 - 答案应该看起来像是今天写的)。 - Peter Mortensen

22

这非常简单。

手动编写base64图像(几乎)不可能,因此有一个Web应用程序可以完成此操作。这是该应用程序的链接:https://www.opinionatedgeek.com/codecs/base64decoder(该解码器适用于普通和URL安全编码,并且可以对您的文本/文档进行解码或编码)。

正如您所说,它以data:image/jpeg;base64,开头。下面是来自维基百科的示例,但它仅仅是一个示例。

<div>
  <img src="data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAAAUA
    AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
        9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot" />
</div>

我知道它只会输出一个红点,但当你没有足够的空间来包含图片或类似物时,它也是有用的。

唯一的问题是这种编码方式非常冗长,可能需要20行左右的代码。希望这可以帮到你!


20

添加Base64数据:

<img src="">

或者

在 JavaScript 中

var id = document.getElementById("image");

id.src = base64Url;

1
为什么需要JavaScript? - Peter Mortensen
1
如果您有静态的Base64 URL,JavaScript就不是必需的。您可以直接将其放入src中。 - Balaji

9
也试试这个吧:
let base64="iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==";
let buffer=Uint8Array.from(atob(base64), c => c.charCodeAt(0));
let blob=new Blob([buffer], { type: "image/gif" });
let url=URL.createObjectURL(blob);
let img=document.createElement("img");
img.src=url;
document.body.appendChild(img);

不建议在生产中使用,因为它只与现代浏览器兼容。


这是什么?JavaScript?TypeScript?这段代码在什么上下文中运行? - Peter Mortensen
@PeterMortensen 这只是纯粹的 JavaScript 代码(带一些 ES6 语法)。您可以在任何地方运行它,例如将其粘贴到 Chrome DevTools 控制台中,在 HTML 脚本标记中或在 .js 文件中。 - Kevin

9
您可以通过将元素的src属性设置为data:image/[image format];base64,[Base64 data]来在HTML中显示Base64图像。
在本例中,src属性中的data:image/jpeg;base64,部分指定了图像的格式(JPEG),而LzlqLzRBQ...部分是图像的Base64数据。
元素的style属性可用于指定图像的显示和大小属性。在这种情况下,display:block将使图像成为块级元素,width:100px;height:100px;设置图像的宽度和高度为100像素。
<!DOCTYPE html>
<html>
  <head>
    <title>Display Base64 Image</title>
  </head>
  <body>
    <img src="
    AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
        9TXL0Y4OHwAAAABJRU5ErkJggg==" />
  </body>
</html>

该标签的src属性设置为。这表示图像是PNG格式,并且Base64数据包含在src属性的base64部分之后。


9
您可以直接在url语句中放置您的数据,例如:
src = 'url(imageData)';

要获取图像数据,您可以使用PHP函数:

$imageContent = file_get_contents("imageDir/" . $imgName);

$imageData = base64_encode($imageContent);

所以您可以复制粘贴imageData的值,直接将其粘贴到您的URL并将其分配给图像的src属性。


但最终输出的是HTML。那么HTML输出是什么? - Peter Mortensen

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接