MessageDigest 类为应用程序提供信息摘要算法的功能,如 MD5 或 SHA 算法。信息摘要是安全的单向哈希函数,它接收任意大小的数据,并输出固定长度的哈希值。
MessageDigest 对象开始被初始化。该对象通过使用 update 方法处理数据。任何时候都可以调用 reset 方法重置摘要。一旦所有需要更新的数据都已经被更新了,应该调用 digest 方法之一完成哈希计算。
对于给定数量的更新数据,digest 方法只能被调用一次。在调用 digest 之后,MessageDigest 对象被重新设置成其初始状态。
该实现可随意选择是否实现 Cloneable 接口。客户端应用程可以通过尝试复制和捕获 CloneNotSupportedException 来测试可复制性:
MessageDigest md = MessageDigest.getInstance("SHA"); try { md.update(toChapter1); MessageDigest tc1 = md.clone(); byte[] toChapter1Digest = tc1.digest(); md.update(toChapter2); ...etc. } catch (CloneNotSupportedException cnse) { throw new DigestException("couldn't make digest of partial content"); }
注意:
(1)如果给定的实现是不可复制的,而事先已经知道摘要的数目,则仍然能够通过实例化几个实例计算中间摘要。
(2)由于历史原因,此类是抽象类,是从 MessageDigestSpi 扩展的。应用程序开发人员只需注意在此 MessageDigest 类中定义的方法;超类中的所有方法是供希望提供自己的信息摘要算法实现的加密服务提供者使用的。
实例:利用该类实现MD5消息摘要算法
package javaSecurity; import java.security.MessageDigest; /** * 使用MessageDigest生成MD5消息摘要 * @author hx * @date 2015年11月12日22:46:30 */ public class MessageDigestTest03 { public static void main(String[] args) throws Exception { byte[] source = "md5".getBytes(); MessageDigest md5 = MessageDigest.getInstance("MD5"); md5.update(source); byte[] result = md5.digest(); String[] strs = {"0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "E", "F"}; StringBuffer buffer = new StringBuffer(); for ( byte b : result ) { buffer.append( strs[ b >>> 4 & 0xF ] ); buffer.append( strs[ b & 0xF] ); } System.out.println( buffer.toString() ); } }
输出结果:
1BC29B36F623BA82AAF6724FD3B16718