所谓"data"类型的Url格式,是在RFC2397中 提出的,目的对于一些“小”的数据,能够在网页中直接嵌入,而不是从外部文件载入。例如对于img这个Tag,哪怕这个图片很是很是的小,小到只有一个 点,也是要从另一个外部的图片文件例如gif文件中读入的,若是浏览器实现了data类型的Url格式,这个文件就能够直接从页面文件内部读入了。javascript
data类型的Url格式早在1998年就提出了,时至今日,Firfox、Opera、Safari和Konqueror这些浏览器都已经支持,可是IE直到7.0版本都尚未支持,IE不支持的东西太多了,也不差这一个。:(php
小例子css
下面这个html代码能够在支持data类型Url的浏览器中运行,例如Firefox。运行后会看到一条蓝色渐变底色的标题。html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head> <style type="text/css"> .title { background-image:url(data:image/gif;base64,R0lGODlhAQAcALMAAMXh96HR97XZ98Hf98Xg97DX97nb98Lf97vc98Tg973d96rU97ba97%2Fe96XS9wAAACH5BAAAAAAALAAAAAABABwAAAQVMLhVBDNItXESAURyDI2CGIxQLE4EADs%3D); background-repeat:repeat-x; height:28px; line-height: 28px; text-align:center; } </style> </head> <body> <div class="title">Hello, world!</div> </body> </html>
这个渐变的蓝色底色其实是用一个1x28的小图片经过横行重复(repeat-x)造成的。这个图片很小,不过104个字节,直接嵌入到html或css文件仍是很合适的。java
data格式的Url最直接的好处是,这些Url本来会引发一个新的网络访问,由于那里是一个网页的地址,如今不会有新的网络访问了,由于如今这里是网页的内容。这样作,会减小服务器的负载,固然同时也增长了当前网页的大小。因此对“小”数据特别有好处。浏览器
data类型Url的形式服务器
既然是Url,固然也能够直接在浏览器的地址栏中输入。网络
data:text/html,<html><body><p><b>Hello, world!</b></p></body></html>测试
在浏览器中输入以上的Url,会获得一个加粗的"Hello, world!"。也就是说,data:后面的数据直接用作网页的内容,而不是网页的地址。编码
简单的说,data类型的Url大体有下面几种形式。
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代码> data:image/gif;base64,base64编码的gif图片数据 data:image/png;base64,base64编码的png图片数据 data:image/jpeg;base64,base64编码的jpeg图片数据 data:image/x-icon;base64,base64编码的icon图片数据
由于Url是一种基于文本的协议,因此gif/png/jpeg这种二进制属于须要用base64进行编码。换句话说,引入base64之后,就能够支持任意形式的数据格式。下面是个png图片的例子,会在浏览器中显示一个Mozilla的图标。
data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAABGdBTUEAAK/INwWK6QAAABl0RVh0U29mdHdhcmUAQWRvYmUgSW1hZ2VSZWFkeXHJZTwAAAHWSURBVHjaYvz//z8DJQAggJiQOe/fv2fv7Oz8rays/N+VkfG/iYnJfyD/1+rVq7ffu3dPFpsBAAHEAHIBCJ85c8bN2Nj4vwsDw/8zQLwKiO8CcRoQu0DxqlWrdsHUwzBAAIGJmTNnPgYa9j8UqhFElwPxf2MIDeIrKSn9FwSJoRkAEEAM0DD4DzMAyPi/G+QKY4hh5WAXGf8PDQ0FGwJ22d27CjADAAIIrLmjo+MXA9R2kAHvGBA2wwx6B8W7od6CeQcggKCmCEL8bgwxYCbUIGTDVkHDBia+CuotgACCueD3TDQN75D4xmAvCoK9ARMHBzAw0AECiBHkAlC0Mdy7x9ABNA3obAZXIAa6iKEcGlMVQHwWyjYuL2d4v2cPg8vZswx7gHyAAAK7AOif7SAbOqCmn4Ha3AHFsIDtgPq/vLz8P4MSkJ2W9h8ggBjevXvHDo4FQUQg/kdypqCg4H8lUIACnQ/SOBMYI8bAsAJFPcj1AAEEjwVQqLpAbXmH5BJjqI0gi9DTAAgDBBCcAVLkgmQ7yKCZxpCQxqUZhAECCJ4XgMl493ug21ZD+aDAXH0WLM4A9MZPXJkJIIAwTAR5pQMalaCABQUULttBGCCAGCnNzgABBgAMJ5THwGvJLAAAAABJRU5ErkJggg==data格式Url的种种应用举例
能够在Html的Img对象中使用,例如
<img src="data:image/x-icon;base64,AAABAAEAEBAAAAAAAABoBQAAF..." />
能够在Css的background-image属性中使用,例如
div.image { width:100px; height:100px; background-image:url(data:image/x-icon;base64,AAABAAEAEBAAAAAAAABoBQAAF...); }
能够在Html的Css连接处使用,例如
<link rel="stylesheet" type="text/css"
href="data:text/css;base64,LyogKioqKiogVGVtcGxhdGUgKioq..." />
能够在Html的Javascript连接处使用,例如
<script type="text/javascript"
href="data:text/javascript;base64,dmFyIHNjT2JqMSA9IG5ldyBzY3Jv..."></script>完整的语法定义
在RFC中,完整的语法定义以下。
dataurl := "data:" [ mediatype ] [ ";base64" ] "," data
mediatype := [ type "/" subtype ] *( ";" parameter )
data := *urlchar
parameter := attribute "=" value
urlchar指的就是通常url中容许的字符,有些字符须要转义,例如"="要转义为"%3D",不过我测试下来,至少在Firefox里面,不转义也是能够的。
parameter能够对mediatype进行属性的扩展,常见的是charset,用来定义编码格式,在多语言状况下须要用到。例以下面的例子。
data:text/plain;charset=UTF-8;base64,5L2g5aW977yM5Lit5paH77yB
这个例子会显示出"你好,中文!"。若是吧charset部分去掉,就会显示乱码,由于我用的是UTF-8编码。
Firefox有一个data类型Url的测试页面,列出了各类格式的data类型Url的测试Url,和测试结果说明。
base64编码和内容的隐秘
把二进制数据转换成为Base64不是什么难事,好比Total Commander就有这样的功能。还有一些在线资源,
http://www.greywyvern.com/code/php/binary2base64http://www.kawa.net/works/js/data-scheme/base64-e.html
有些在线转换把base64里面的“=”转换成为%3D,这个在Url中和“=”是同样的,不转换也没什么问题。
固然,这种Url还有一种隐秘的好处,就是将一些道貌岸然者不喜欢的东西,冠冕堂皇的放在页面上,你懂的。