MD5加密介绍及其工具类
1.MD5介绍
MD5即Message-Digest Algorithm 5(信息-摘要算法5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD5实现。将数据(字节串)运算为另一固定长度值(128bit),是杂凑算法的基础原理,MD5的前身有MD2、MD3和MD4。
2.MD5算法具有以下特点:
- 压缩性:任意长度的数据,算出的MD5值长度都是固定的。(128bit:128个0和1 32位)
- 容易计算:从原数据计算出MD5值很容易。
- 抗修改性:对原数据进行任何改动,哪怕只修改1个字节,所得到的MD5值都有很大区别。
- 强抗碰撞:已知原数据和其MD5值,想找到一个具有相同MD5值的数据(即伪造数据)是非常困难的。
3.MD5应用场景
- 一致性验证
- 数字签名
- 安全访问认证
4.MD5工具类
package xs.utils.md5;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
/**
* @ClassName: MD5Utils
* @Description: TODO(MD5加密算法工具类)
* @author nameisbill
* @date 2017年1月16日 下午5:15:19
*/
public class MD5Utils {
private static final char[] DIGITS = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e',
'f' };
/**
* 对字符串进行MD5加密
* @param text 明文
* @return 密文
*/
public static String md5(String text) {
MessageDigest msgDigest = null;
try {
msgDigest = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e) {
throw new IllegalStateException("System doesn't support MD5 algorithm.");
}
try {
msgDigest.update(text.getBytes("UTF-8"));
} catch (UnsupportedEncodingException e) {
throw new IllegalStateException("System doesn't support your EncodingException.");
}
byte[] bytes = msgDigest.digest();
String md5Str = new String(encodeHex(bytes));
return md5Str;
}
/**
* 对字符串进行MD5加密,用秘钥进行加权
* @param key 密匙
* @param text 明文(报文)
* @return 密文 (摘要)
*/
public static String md5(String key, String text) {
String s = text + (key == null ? "" : key);
return md5(s);
}
private static char[] encodeHex(byte[] data) {
int l = data.length;
char[] out = new char[l << 1];//补充
// two characters form the hex value.
for (int i = 0, j = 0; i < l; i++) {
out[j++] = DIGITS[(0xF0 & data[i]) >>> 4];
out[j++] = DIGITS[0x0F & data[i]];
}
return out;
}
public static void main(String[] args) {
System.out.println(md5("1f75c89f172048888586ab813b0b6fde","123456"));
}
}