Introduction

Data URL

Data URL Scheme–允许我们使用inline-code方式在网页中包含数据, 从而将一些小数据, 直接嵌入到
网页中, 从而不用从外部文件载入, 一般用于图片.

其中传统的图片使用: <img src="images/image.png">方式来加载资源并显示, 而在Data URL中内嵌的
图片则使用: <img src="data:image/png;base64,图片编码">方式来直接显示图片, 省略了图片的加载.

即DATA URL直接使用URL传递方式来内嵌图片.

Advantage

优点:

  • 减少资源的请求链接数
  • 访问外部资源受限时, 使用Data URL可以达到很好的效果

缺点:

  • Data URL形式的图片不会被浏览器缓存,这意味着每次访问这样页面时都被下载一次
  • Base64编码的数据体积通常是原数据的体积4/3
  • 在移动端性能可能偏低

对于缓存问题, 可以使用在css文件的background-image样式规则使用Data URI Scheme, 从而跟随CSS文件
一起被浏览器缓存.

Scenarios

  • 访问外部资源受限
  • 图片是在服务器端用程序动态生成,每个访问用户显示的都不同时
  • 当图片的体积太小,占用一个HTTP会话不是很值得时

Format

Format

整个URL格式: data:[<mime type>][;charset=<charset>][;<encoding>],<encoded data>, 其中

  • data: 协议名称
  • mime type: 数据类型(img/png, text/plain等), 可选字段
  • charset: 源文本的字符编码方式, 可选项
  • encoding: 数据编码方式, 默认US-ASCII, BASE64两种
  • encoded data: 编码后的数据

Type

目前支持的URL Scheme类型:

  • data:,文本数据
  • data:text/plain,文本数据
  • data:text/html,HTML代码
  • data:text/html;base64,base64编码的HTML代码
  • data:text/css,CSS代码
  • data:text/css;base64,base64编码的CSS代码
  • data:text/javascript,Javascript代码
  • data:text/javascript;base64,base64编码的Javascript代码
  • 编码的gif图片数据
  • 编码的png图片数据
  • 编码的jpeg图片数据
  • 编码的icon图片数据

Example

下面以一个python例子来讲解使用requests来进行图片的读取, 上传.

1
2
3
4
5
6
7
8
9
10
import requests
import base64

url = 'http://127.0.0.1:5000/dama/file'

text = ''

files = {'file': base64.b64decode(text.split(',', 1)[-1])}
data = {'type': 'upload'}
rsp = requests.post(url, data=data, files=files)