开发者对base64编码肯定很熟悉,是否对它有很清晰的认识就不一定了。实际 上base64已经简单到不能再简单了,如果对它的理解还是模棱两可实在不应该。大概介绍一下base64的相关内容,花几分钟时间就可以彻底理解它。文 章下边贴了一个base64的编解码器,方便阅读文章的同时来实验。
一. base64编码由来
为什么会有base64编码呢?因为有些网络传送渠道并不支持所有的字节,例如传统的邮件只支持可见字符的传送,像ascii码的控制字符就 不能通过邮件传送。这样用途就受到了很大的限制,比如图片二进制流的每个字节不可能全部是可见字符,所以就传送不了。最好的方法就是在不改变传统协议的情 况下,做一种扩展方案来支持二进制文件的传送。把不可打印的字符也能用可打印字符来表示,问题就解决了。base64编码应运而生,base64就是一种 基于64个可打印字符来表示二进制数据的表示方法。
二. base64编码原理
看一下base64的索引表,字符选用了a-z、a-z、0-9、+、/ 64个可打印字符。数值代表字符的索引,这个是标准base64协议规定的,不能更改。64个字符用6个bit位就可以全部表示,一个字节有8个bit 位,剩下两个bit就浪费掉了,这样就不得不牺牲一部分空间了。这里需要弄明白的就是一个base64字符是8个bit,但是有效部分只有右边的6个 bit,左边两个永远是0。
那么怎么用6个有效bit来表示传统字符的8个bit呢?8和6的最小公倍数 是24,也就是说3个传统字节可以由4个base64字符来表示,保证有效位数是一样的,这样就多了1/3的字节数来弥补base64只有6个有效bit 的不足。你也可以说用两个base64字符也能表示一个传统字符,但是采用最小公倍数的方案其实是最减少浪费的。结合下边的图比较容易理解。man是三个 字符,一共24个有效bit,只好用4个base64字符来凑齐24个有效位。红框表示的是对应的base64,6个有效位转化成相应的索引值再对应 base64字符表,查出man对应的base64字符是twfu。说到这里有个原则不知道你发现了没有,要转换成base64的最小单位就是三个字节,对一个字符串来说每次都是三个字节三个字节的转换,对应的是base64的四个字节。这个搞清楚了其实就差不多了。
但是转换到最后你发现不够三个字节了怎么办呢?愿望终于实现了,我们可以用两 个base64来表示一个字符或用三个base64表示两个字符,像下图的a对应的第二个base64的二进制位只有两个,把后边的四个补0就是了。所以 a对应的base64字符就是qq。上边已经说过了,原则是base64字符的最小单位是四个字符一组,那这才两个字 符,后边补两个=吧。其实不用=也不耽误解码,之所以用=,可能是考虑到多段编码后的base64字符串拼起来也不会引起混淆。由此可见 base64字符串只可能最后出现一个或两个=,中间是不可能出现=的。下图中字符bc的编码过程也是一样的。
三. 总结
说起base64编码可能有些奇怪,因为大多数的编码都是由字符转化成二进制的过程,而从二进制转成字符的过程称为解码。而base64的概念就恰好反了,由二进制转到字符称为编码,由字符到二进制称为解码。
base64编码主要用在传输、存储、表示二进制等领域,还可以用来加密,但是这种加密比较简单,只是一眼看上去不知道什么内容罢了,当然也可以对base64的字符序列进行定制来进行加密。
base64编码是从二进制到字符的过程,像一些中文字符用不同的编码转为二 进制时,产生的二进制是不一样的,所以最终产生的base64字符也不一样。例如上网对应utf-8格式的base64编码是5lik572r, 对应gb2312格式的base64编码是yc/n+a==。
function base64encode($str) { $base64 = [ a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u, v, w, x, y, z, 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '+', '/' ]; $len = strlen($str); $rstr = ; for($j=0; $j
以上就介绍了了解base64的原理, 并用php实现,包括了方面的内容,希望对php教程有兴趣的朋友有所帮助。