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