数据加密:
在计算机加密的世界里,有很多很多种不同的加密方式,如MD5,SHA1,Base64等。有的是单向加密,只能通过明文得到密文,无法反过来,通过密文解码得到明文,像MD5,Sha1这样的加密算法,不过md5的32位密文,好像被一个女的破译过。有的这是双向加密的,既可以得到密文,也可以得到明文。
这里简单介绍2个加密的方式:Base64加密与MD5加密
Base64加密&解密
base64是双向加密的方式,spring给我们提供了一个工具类:org.springframework.util.Base64Utils
,我们可以通过这个工具类进行简单的加密解密工作;
//加密
byte[] encode = Base64Utils.encode("zhubajie".getBytes());
String string = new String(encode,"UTF-8");//转成字符串
System.out.println(string);//原字符串:zhubajie --> 输出为:emh1YmFqaWU=
//解密
byte[] decode = Base64Utils.decode(string.getBytes("UTF-8"));
string = new String(decode,"UTF-8");//转成字符串
System.out.println(string);//原字符串:emh1YmFqaWU= --> 输出为:zhubajie
Base64工作原理:
点击这里跳转到原理学习页面
对于数据加密来讲,base64只是达到了让人看到数据,不知道数据的内容,而无法做到真正的安全,所以base64另外一个用途是用来进行数据的传输.
MD5加密
MD5是单向加密,目前网上所谓的MD5解密,是建立在大数据面前,通过撞库来进行解密的.我们可以使用apache给我们提供的加密工具类:org.apache.commons.codec.digest.DigestUtils
进行简单的MD5加密:
//加密
String string = "zhubajie";
String md5Hex = DigestUtils.md5Hex(string);
System.out.println(md5Hex);//原字符串:zhubajie --> 380f38ebd3d1ae0a34906fda9dd08c1e
MD5原理
MD5是一个安全的散列算法,有两个特点:
1、输入两个不同的明文(一段原始的数字信息)不会得到相同的输出值
2、根据输出值,不能得到原始的明文,即过程不可逆
要解密MD5没有现成的算法,只能用穷举法,把可能出现的明文,用MD5算法散列之后,把得到的散列值和原始的数据形成一个一对一的映射表,然后在所谓的解密的时候,都是通过这个映射表来查找其所对应的原始明文。
所以,绝对没有一种算法,可以通过输出加密后的散列值算出原始明文。