MD5(Message-Digest Algorithm 5(信息-摘要算法 5)),是一种算法,不是加密,用于确保信息传输完整一致。它是一种单向散列算法,不可逆向的。消息摘要可以看作原始数据的指纹,指纹不同则原始数据不同。MD5可以为任何文件产生一个同样独一无二的“数字指纹”,如果任何人对文件做了任何改动,其MD5值也就是对应的“数字指纹”都会发生变化。
通常步骤
调用MessageDigest对象的update和digest方法
流数据的特殊处理:
使用DigestInputStream或DigestOutputStream包装MessageDigest对象,
调用DigestInputStream的read方法或DigestOutputStream的write方法读写完数据并将流关闭后,
再调用MessageDigest对象的digest方法,流中的数据就全被摘要处理了。
MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。信息摘要是安全的单向哈希函数,它接收任意大小的数据,并输出固定长度的哈希值。
MessageDigest 对象开始被初始化。该对象通过使用 update 方法处理数据。任何时候都可以调用 reset 方法重置摘要。一旦所有需要更新的数据都已经被更新了,应该调用 digest 方法之一完成哈希计算。
对于给定数量的更新数据,digest 方法只能被调用一次。在调用 digest 之后,MessageDigest 对象被重新设置成其初始状态。
package com.study.messagedigest;
import java.security.MessageDigest;
/**
* 数字摘要
*
* @ClassName: MessageDigestTest
* @Description: TODO
* @author 我夕
* @date 2012-5-17
*/
public class MessageDigestTest {
/**
* @param args
* @throws Exception
*/
public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub
md5();
}
/**
*
* @return
* @throws Exception
*/
private static String md5() throws Exception {
MessageDigest digest = MessageDigest.getInstance("MD5");
digest.update("hello java !".getBytes("UTF-8"));
byte[] result = digest.digest();
//为了便于调试观察,写个方法将字节数组转换成16进制
System.out.println("消息摘要内容:"+toHex(result));
System.out.println("消息摘要长度:" + result.length);
return null;
}
// 字节数组转成16进制
private static String toHex(byte[] buf) {
StringBuffer stringBuffer = new StringBuffer();
for (int i = 0; i < buf.length; i++) {
int hi = ((buf[i] >> 4) & 0x0f);
int lo = buf[i] & 0x0f;
stringBuffer.append(hi > 9 ? (char) ((hi - 10) + 'a')
: (char) (hi + '0'));
stringBuffer.append(lo > 9 ? (char) ((lo - 10) + 'a')
: (char) (lo + '0'));
}
return stringBuffer.toString();
}
}
经过测试大家会发现,不管要生成的消息摘要的内容怎么改变其长度都是16,都不会改变,也就是说MD5其生成的长度是固定的,额外其生成的消息摘要只要其内容一发生变化其结果必然变了,这也就是md5可以很好的作为判断一个文件是否被他人篡改过。