上一次,我写了一篇《Data URL的简介与使用》(http://verymuch.site/2017/12/14/Data URL简介与使用/),该文章主要先容了什么是Data URL,其优缺点以及若何使用。其中有一个隐含在文中的主要观点,那就是Data URL是Base64编码的,且Base64编码的数据体积通常是原数据的体积4/3。
不知道人人会不会有这样的疑问:
为什么图片转成Base64编码,就可以直接内联到HTML中显示呢?
为什么Base64编码后,体积会增大1/3呢?
若是你对此也有疑问的话,就往下一看事实吧。
我们知道HTTP协议是文本协议,不同于通例的二进制协议那样直接举行二进制传输。Base64编码是 从二进制到字符的历程,可用于在HTTP环境下通报较长的标识信息。
首先Base64是一种编码算法,为什么叫做Base64呢?实在缘故原由也很简朴,是因为该算法共包罗64个字符。包罗大小写拉丁字母各26个、数字10个、加号 + 和斜杠 / ,共64个字符。此外另有等号 = 用来作为后缀用途。
字符与索引的对应关系如下图所示。
但,为什么Base64编码算法只支持64个字符呢?
首先,我们先回首下ASCII码。ASCII码的局限是0-127,其中0-31和127是控制字符,共33个。其余95个,即32-126是可打印字符,包罗数字、大小写字母、常用符号等。如下图所示,图片泉源(https://zh. *** .org/wiki/ASCII)。
早期的一些传输协议,例如邮件传输协议 *** TP,只能传输可打印的ASCII字符。这样原本的8bit字节码(0-255)就会超出使用局限,从而导致无法传输。
这时,就产生了Base64编码,它行使 6bit字符来表达原本的8bit字符 。
上面我们知道了什么是Base64编码,知道了其包罗的64个字符。它主要是通过6bit字符来表达原本的8bit字符。接下来我们一起学习下这一历程是若何举行的。
首先,6bit显然不够容纳8bit的数据。6和8的最小公倍数是24,以是我们用4个Base64字符恰好能够示意三个传统的8bit字符。如下所示,字符串 Man 的编码图解如下:
Man 的编码效果为 TWFu ,显然,Base64编码会多1/3的长度,这也注释了文中开头的疑问,为什么Base64编码后的体积会大1/3。
Man 这个字符串的长度恰好是3,我们能用4个Base64来示意。若是待编码的字符串长度不是三的倍数时应该怎么处置呢?
这是需要做一个特殊处置,假设待编码字符串长度为10。这前9个字符可以用12个Base64字符示意。第10个字符的前6bit作为一个Base64字符, 剩下的2bit后面需要先补0,补到6位(此处补4个0) 作为第二个Base64字符,至于第三个和第四个Base64字符,虽然没有相对应的内容,我们仍需 以 = 填充 。
如下图所示, A 对应的Base64编码为 *** == , BC 对应的Base64编码为 QkM= 。
最后的问题就是解码啦,解码的历程比较简朴。 去掉末尾的等号 = 。剩下的Base64字符,每8bit组成一个8bit字节,最后剩余不足8位的抛弃即可。
本文篇幅较短,旨在简朴先容Base64编码原理。信赖看完之后,人人一定能够明白为什么Base64编码后体积会增大1/3,而不再是死记硬背这一特点。至少有这个收获就够啦。
《奇舞周刊》是360公司专业前端团队「 奇舞团 」运营的前端手艺社区。关注民众号后,直接发送链接到后台即可给我们投稿。
编者按:本文作者岑岭,360奇舞团前端工程师,W3C性能事情组/WOT事情组成员。
原文 http://mp.weixin.qq.com/s1.阿里云: 本站现在使用的是阿里云主机,平安/可靠/稳固。点击领取2000米代金券、领会最新阿里云产物的种种优惠流动点击进入
本文导读目录: 1、黑客让你把账号密码发给他值得相信吗? 2、对于黑客你有怎样的理解? 3、黑客真的有那么神奇吗 4、黑客与电脑小白对话全集有哪些? 5、真正意义上的黑客,到底可以厉害...
最先按住Alt F4,以后会弹出来一个后台管理的选择框,以后二愣子现代都市干了 是要黑他人的网络服务器吗?若是是,提议用压测手机软件百度搜索上搜就会有哦 变成我的天下的大牌明星实况主播,随后他人就害怕...
什么是散文(散文的概念及写作技巧) 岳阳楼 一、什么是散文? 中国是一个散文大国。古今的散文大家和作品,享誉很高。新时期以来,我国的散文创作出 现了前所未有的好势头,散文创作持续热闹火爆,涌现了...
简要教程 aos.js是一款效果超赞的页面滚动米素动画jQuery动画库插件。该动画库可以在页面滚动时提供28种不同的米素动画效果,以及多种easing效果。在页面往回滚动时,米素会恢复到原来的状态...
如果要成为黑客要学些什么24小时在线的黑客介绍一个(24小时学会黑客攻防)黑客用什么品牌笔记本电脑怎么雇黑客(自雇移民)黑客为什么要入侵电脑锡安是不是虚拟的(塞娜是不是绿了卢锡安)为什么黑客喜欢汇编黑...
引言随着互联网架构的高速发展,信息安全越来越受到社会的关注,发展越来越标准化、流程化。在如今的渗透攻击和测试中,个人自身完成一整套渗透攻击链已变的越来越困难,于是,在各个阶段涌现出一批又一批的垂直化渗...