MD5(即Message Digest Algorithm)是一种hash散列算法不是加密算法,用于对一段信息产生信息摘要,以防止信息被篡改,是不可逆摘要算法(但是现在存在彩虹表可破解),主要用于校验数据一致性和数据签名.
还有SHA,SHA-1等摘要算法,其中SHA-1与MD5的最大区别在于其摘要比MD5摘要长32比特
public class Md5AndShaSignatue {
public static void main(String[] args) {
// TODO Auto-generated method stub
String data = "12345";
String nd = md5(data);
System.out.println(nd);
}
private static String md5(String data) {
// TODO Auto-generated method stub
try {
// 获得MD5摘要算法的 MessageDigest 对象
MessageDigest mdInst = MessageDigest.getInstance("MD5");
// 使用指定的字节更新摘要
mdInst.update(data.getBytes());
// 获得密文
byte[] md = mdInst.digest();
// 把密文转换成十六进制的字符串形式
StringBuffer hexString = new StringBuffer();
// 字节数组转换为 十六进制 数
for (int i = 0; i < md.length; i++) {
String shaHex = Integer.toHexString(md[i] & 0xFF);
if (shaHex.length() < 2) {
hexString.append(0);
}
hexString.append(shaHex);
}
return hexString.toString();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return "";
}
}
主要相关步骤:
利用MessageDigest类用于为应用程序提供信息摘要算法的功能 接收任意大小的数据,输出固定长度的哈希值
(1)通过MessageDigest.getInstance("MD5")进行实例化。
(2)使用update()指定产生摘要的字节数组
(3)使用digest()方法来计算摘要(即生成散列码)
(4)将摘要结果数组(byte数组)转换为十六进制的字符串形式