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;
}
}