• 浏览器中的data类型的Url格式,%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文件还是很合适的。

    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代码>
    编码的gif图片数据
    编码的png图片数据
    编码的jpeg图片数据
    编码的icon图片数据
    

    因为Url是一种基于文本的协议,所以gif/png/jpeg这种二进制属于需要用base64进行编码。换句话说,引入base64以后,就可以支持任意形式的数据格式。下面是个png图片的例子,会在浏览器中显示一个Mozilla的图标。

    格式Url的种种应用举例

    可以在Html的Img对象中使用,例如

    <img src="..." />

    可以在Css的background-image属性中使用,例如

    div.image {
    100px;
    height:100px;
    background-image:url(...);
    }
    

    可以在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中和“=”是一样的,不转换也没什么问题。

    (注:这篇文章是源自:http://blog.csdn.net/roadmore/article/details/38498719,主要是方便自己以后查看)

  • 相关阅读:
    zookeeper java调用及权限控制
    走进C++程序世界------IO标准库介绍
    Unity3d 镜面折射 vertex and frag Shader源代码
    servlet上传文件报错(二)
    模仿linux内核定时器代码,用python语言实现定时器
    6.12交流
    python学习(三) 使用字符串
    JAVA面试(四)
    python学习(二) 列表和元组
    C++面试题(三)
  • 原文地址:https://www.cnblogs.com/Yuuki-/p/8024944.html
Copyright © 2020-2023  润新知