MD5算法:虽然已经被破解,但任然广泛应用于各个领域中
如文件校验:当我们下载文件时为了保证文件的安全性,我们可以在其网站上找到对应的md5值进行校验,如果md5值不一致,也就是说文件被人动过(一般都是挂马了),所以文件校验领域应用十分广泛。
如数字签名证书,当我们访问12306时,经常会出现该网站证书已过期,问你是否继续访问,在一般情况下是自己的电脑时间设置不正确,但除开这种情况也就是你访问的网站不是同一个网站。
还有就是当作密钥,这个在我们生活中还算比较的常用,因为md5算法开源,我们可以免费使用,而且在没有密钥的情况下破解成本较高,在一般情况下我们都还是采用md5算法
package com.jack.md5;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class MD5Util {
public static final String MD5(String src) {
//char[] hexDigits = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };
byte[] input = src.getBytes();
try {
MessageDigest digest = MessageDigest.getInstance("MD5");
//官方说法更新摘要
//个人理解:就是找到要加密的字符串,放置到update()中等待digest()方法进行产出
//就像是在机器的两头:一头的将原材料放进去,一头是产品的输出
//获取输入
digest.update(input);
//获得产出
input = digest.digest();
//下面就是进行十六进制的转换
int length = input.length;
StringBuffer strBuff = new StringBuffer();
for(int i = 0;i<length;i++)
{
//将字符转变成对应的ASSIC值
int val = ((int)input[i])&0xff;
//转变成对应的值后小于4位
if(val<16)
{
strBuff.append("0");
}
strBuff.append(Integer.toHexString(val));
// strBuff.append(hexDigits[val%16]);
}
return strBuff.toString();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return src;
}
}