一、对称加密
所谓的对称加密就是加密跟解密使用同一把密钥
常见的对称加密算法有AES,DES等等,下面以DES加密算法为例
Java语言实现DES加密:
![](https://img-blog.csdnimg.cn/img_convert/aafd432941237cac70587a2b9607629f.png)
Java语言实现DES解密:
![](https://img-blog.csdnimg.cn/img_convert/27bdd45698eeff3f128a0ee7e2006cf1.png)
对于不同的对称加密算法,密钥的位数是不同的。对于DES加密算法,规定了密钥(key)必须是8个字节,对于AES加密算法,规定了密钥(key)必须16个字节。上述使用的是DES加密算法,所以密钥(key)是“12345678”也就是8个字节。如果不按照规定,那么会报如下错误。
![](https://img-blog.csdnimg.cn/img_convert/1e94dbe3bb70fec8de4a123a63a29bcd.png)
二、非对称加密
所谓的非对称加密就是用公钥加密就必须用私钥解密,用私钥加密就必须用公钥解密
常见的对称加密算法有RSA, DSA,ECC等等,下面以RAS加密算法为例
Java语言实现RSA加密:
![](https://img-blog.csdnimg.cn/img_convert/cb397283395065f6898f047d23284a84.png)
Java语言实现RSA解密:
![](https://img-blog.csdnimg.cn/img_convert/bbdcf5d7ae879baf78103f7becfdeb89.png)
三、可读性算法(Base64)
为什么引入Base64
ascii码只有表示正数的符号
![](https://img-blog.csdnimg.cn/img_convert/d0944fcf9d7380729b762abd537ea7bc.png)
但一个byte为负数时,转为String打印出来时在ascii码中没法找到,那么就会打印乱码
![](https://img-blog.csdnimg.cn/img_convert/551d29071c3811b0eeec4fa483753869.png)
乱码可读性差,所以Base64也就应运而生
什么是Base64
Base64不是加密算法,是可读性算法。
Base64目的不是保护我们的数据,目的是为了增强可读性
Base64是由64个字符(大写A-Z, 小写a-z, 数字0-9, 两个符号+和/)
base64 按照把数据按照3个字节为一组,一个字节是8位, 一共就是24位, 把这24位, 拆成6位(6位高位补0 刚好就是表示0-63)一组, 分4组。如果不够三个字节,Base64就会自动补充到三个字节。补充多少个字节,编码后就在后面加多几个=
![](https://img-blog.csdnimg.cn/img_convert/8c30c697c8189caad59b7f4334d197e8.png)
比如,此时1为一个字节,得Base64自动补充两个字节到三个字节,因为补充了两个字节,所以编码后在后面加了两个=号
![](https://img-blog.csdnimg.cn/img_convert/deb3503f04bcc71c4788062172adb0b3.png)
比如,此时12为两个字节,得Base64自动补充一个字节到三个字节,因为补充了一个字节,所以编码后在后面加了一个=号
![](https://img-blog.csdnimg.cn/img_convert/9eda36518cd5c6b7e7c8313a732b5bfa.png)
比如,此时12为三个字节,得Base64无需自动补充,所以编码后在后面就没有=号
Java语言实现Base64编码解码
![](https://img-blog.csdnimg.cn/img_convert/6320205ff236c8a0e2cf84a6347c62bc.png)