BASE64编码简介

  BASE64是一种常用的可逆编码形式,常用于把二进制编码转换为字符形式的数据。编码后的字符串包含a-z、A-Z、0-9、+、/,共64个字符。64个字符需要用6位来表示,从0开始表示成数字0-63。【其实共有65个字符,“=”是填充字符,后面会说到。】

 

码值字符 码值字符 码值字符 码值字符
0A16Q32g48w
1B17R33h49x
2C18S34i50y
3D19T35j51z
4E20U36k520
5F21V37l531
6G22W38m542
7H23X39n553
8I24Y40o564
9J25Z41p575
10K26a42q586
11L27b43r597
12M28c44s608
13N29d45t619
14O30e46u62+
15P31f47v63/

此时,长度为3个字节的数据经过编码后就会变成4个字节。

例:

  字符串“QUT”经过编码后就会变成“UVVU”。

QUT
010100010101010101010100
UVVU

  长度为3的字节数位数为3×8=24,刚好可以分成6×4。但如果数据的字节数不是3的倍数,则其位数就不是6的倍数,那么需要就不能精确地划分成6位的块。此时,需在原数据后面添加1个或2个零值字节,使其字节数是3的倍数。然后,在编码后的字符串后面添加1个或2个等号“=”,用以表示所添加的零值字节数。

例:

  字符串“QU”经过编码后就会变成“UVU=”。

QU 
010100010101010100000000
UVU=

  字符串“Q”经过编码后就会变成“UQ==”。

Q  
010100010000000000000000
UQ==

 

BASE64加密常用于HTML内嵌Base64编码图片。

  前端在实现页面时,对于一些简单图片,通常会选择将图片内容直接内嵌在页面中,避免不必要的外部资源加载,增大页面加载时间,但是图片数据是二进制数据,该怎么嵌入呢?绝大多数现代浏览器都支持一种名为Data URLs的特性,允许使用BASE64对图片或其他文件的二进制数据进行编码,将其作为文本字符串嵌入网页中。以百度搜索首页为例,其中语音搜索的图标是个背景图片,其内容以Data URLs形式直接写在CSS中,这个css内容又直接嵌在HTML页面。

 

  Data URLs 格式为:url(data:文件类型;编码方式,编码后的文件内容)。但如果图片较大,图片的色彩层次比较丰富,则不适合使用这种方式,因为其BASE64编码后的字符串非常大,会明显增大HTML页面,影响加载速度。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值