Base64加密与解密

Base64加密方式是将原文经过简单的字符转换,转换成不easy被肉眼看出的字符编码。Base64加密经常使用在HTTP环境下传递较长的标识信息确保不破坏HTTP的请求格式,Base64的加密原理是将3个8位二进制转换为4个6位二进制,不足6位时高位补0 。以确保其值为64个可能,这就是Base64来源。

例如以下图就是Base64标准中的编码表。


取个样例:

须要加密的原文是“ABC”这三个字母,通过ASCII表得到这个三个字母的值的二进制表示为(去查ASCII表):

字符A:01000001  (65)

字符B:01000010  (66)

字符C:01000011  (67)

所以须要加密的原文的码流为01000001 01000010 01000011,经过转换成4个6位二进制得到

010000  010100 001001  000011

然后高位补0得到的8位二进制得到

00010000   00010100    00001001    00000011   

16                20                   9                   3          所相应的十进制为

Q                  U                    J                    D          Base64编码

由此能够看到。“ABC”经过Base64加密后变成了“QUJD”,从长度能够看出添加了1/4,从结果上来说。加密后的字符仅仅有64种可能。事实上想想,之所以会把8位转换成6位。也是这种道理。

毕竟2的6次方减1等于63!这也是Base64加密的原理。Base64解密的原理恰好是加密的反向过程,过程是可逆的。

当反向解码后就会得到原文。尽管Bae64加密的数据安全性不是非常高。可是肉眼上也不太easy看出来原文。发送Email时对内容的加密就是採用的Base64。这是有历史原因的。

下面两种情况

1、中文加密:仅仅加密一个中文汉字时。因为一个中文汉字是两个字节!所以从16位自己主动填充到24位bits。所得Base64加密结果是4个字节。

2、 原文(bits)%24 != 0 ,自己主动填充成24bits的整倍数。

关于Base64很多其它的使用方法这里就不用说了,详细的java代码实现见:http://download.csdn.net/detail/main_stage/7507185


原文地址:https://www.cnblogs.com/jhcelue/p/6803222.html