java MD5应用

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可以很好的作为判断一个文件是否被他人篡改过。

你可能感兴趣的:(java,Algorithm,exception,算法,String,byte)