图片的base64表示

图片的base64表示

文章目录

在调用大模型API时候,我们常常使用base64形式表示图片。

data:image/ 开头的字符串是一种名为 Data URI(或称 Data URL)的方案。

简单来说,它允许你将文件(在这里是图片)的内容直接嵌入到文本(如HTML、CSS或JavaScript代码)中,而不是通过一个URL链接到外部文件。


详细解析

我们来分解一个典型的 Data URI 结构:

复制代码
data:[<mediatype>][;base64],<data>

以一个简单的1x1像素的红色GIF图片为例:

html 复制代码
<img src="">

这个 src 属性里的字符串就是 Data URI,我们来逐段分析它:

  1. data:

    • 这是协议头,声明这是一个 Data URI。就像 http:ftp: 一样,它告诉浏览器如何解析后面的内容。
  2. image/gif

    • 这是 MIME 类型(MIME Type),用于告诉浏览器嵌入的数据是什么类型的文件。
    • image/gif 表示这是一个 GIF 图片。
    • 其他常见的图片类型还有 image/pngimage/jpegimage/svg+xml 等。
  3. ;base64

    • 这是编码方式。它告诉浏览器,后面的数据是使用 Base64 编码的。
    • 图片是二进制文件,不能直接作为文本放在代码里。Base64 是一种将二进制数据转换成由 ASCII 字符(A-Z, a-z, 0-9, +, /)组成的文本字符串的编码方法。
    • 这个部分是可选的,但对于图片等非文本文件来说,几乎总是会使用 Base64 编码。
  4. ,

    • 这是一个分隔符,它将元数据(协议、MIME类型、编码方式)和实际的文件数据分开。
  5. R0lGODlhAQABAIAAAAD/AAAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==

    • 这就是图片文件的实际内容,经过 Base64 编码后得到的长字符串。浏览器读取这个字符串后,会将其解码还原成原始的二进制图片数据,然后显示出来。

为什么要使用 Data URI?

优点:

  1. 减少HTTP请求:网页中每张外部图片都需要一次单独的HTTP请求来加载。如果页面上有很多小图标,使用 Data URI 可以将它们全部嵌入到HTML或CSS文件中,从而减少服务器的请求次数,在某些情况下可以加快页面加载速度。
  2. 独立性/自包含:HTML或CSS文件本身就包含了所有需要的图片资源,不需要依赖外部文件。这使得分享或部署单个文件变得非常方便,比如在发送HTML邮件时。

缺点:

  1. 体积增大 :Base64编码后的数据体积通常会比原始二进制数据大 33% 左右。
  2. 无法利用浏览器缓存 :常规的图片文件(如 logo.png)在第一次加载后会被浏览器缓存。当你在网站的其他页面再次使用这张图片时,浏览器会直接从缓存中读取,速度非常快。而 Data URI 嵌入在HTML或CSS文件中,每次加载这个HTML/CSS文件时,图片数据都会被重新加载,无法被单独缓存。
  3. 可读性和维护性差:一大串无意义的字符混在代码里,使得代码难以阅读和维护。如果你想修改图片,必须重新生成整个Base64字符串并替换它。
  4. 不适合大图片:由于体积增大和无法缓存的问题,Data URI 非常不适合用于较大的图片。它通常只用于非常小的图标或背景图案。

总结

data:image/...;base64,... 是一种将图片文件通过Base64编码转换为文本字符串,并直接嵌入到代码中的技术。它的主要目的是减少HTTP请求,但代价是文件体积增大和无法有效利用缓存,因此最适合用于小图标等小型图片资源。

相关推荐
未来之窗软件服务6 分钟前
幽冥大陆(八十五)Python 水果识别ONNX转手机mobile —东方仙盟练气期
开发语言·python·模型训练·仙盟创梦ide·东方仙盟
莓有烦恼吖10 分钟前
基于AI图像识别与智能推荐的校园食堂评价系统研究 05-审核机制模块
java·服务器·python
linghuocaishui19 分钟前
京东用工平台实践:亲测案例复盘分享
人工智能·python
你怎么知道我是队长25 分钟前
python---新年烟花
开发语言·python·pygame
智算菩萨29 分钟前
【Python机器学习】主成分分析(PCA):高维数据的“瘦身术“
开发语言·python·机器学习
技术小甜甜1 小时前
[AI 工程实践] 远程调用 Ollama 报错解析:如何解决“本地文件找不到”的误区
ai·自动化·llm·agent·ollama·’人工智能·aider
540_5402 小时前
ADVANCE Day33
人工智能·python·机器学习
水龙吟啸2 小时前
基于Orbbec-Gemini深度相机与SFM-2D to 3D重建算法、手部识别视觉算法、Unity运动控制的3D水果切割游戏
python·深度学习·神经网络·c#·游戏引擎·3d视觉·3d重建
BBB努力学习程序设计3 小时前
深入理解 Python 中的深浅拷贝(Shallow Copy & Deep Copy):避免数据引用的 “坑”
python
BBB努力学习程序设计3 小时前
深入理解 Python 中的闭包(Closure):封装状态的函数式编程利器
python