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