散列函数非常有用,几乎出现在所有信息安全应用程序中。
哈希函数是将数字输入值转换为另一个压缩数值的数学函数。 散列函数的输入具有任意长度,但输出始终具有固定长度。
散列函数返回的值称为信息摘要或简称散列值。 下图说明了散列函数。
Java提供了一个名为MessageDigest
的类,它属于java.security
包。 此类支持诸如SHA-1
,SHA 256
,MD5
算法之类的算法,以将任意长度的消息转换为信息摘要。
要将给定邮件转换为邮件摘要,请按照以下步骤进行操作 -
第1步:创建MessageDigest对象
MessageDigest
类提供名为getInstance()
的方法。 此方法接受String
变量,该变量指定要使用的算法的名称,并返回实现指定算法的MessageDigest
对象。
使用getInstance()
方法创建MessageDigest
对象,如下所示 -
MessageDigest md = MessageDigest.getInstance("SHA-256");
第2步:将数据传递给创建的MessageDigest对象
创建消息摘要对象后,需要将消息/数据传递给它。 可以使用MessageDigest
类的update()
方法执行此操作,此方法接受表示消息的字节数组,并将其添加/传递给上面创建的MessageDigest
对象。
MessageDigest md = MessageDigest.getInstance("SHA-256");
md.update(msg.getBytes());
第3步:生成消息摘要
可以使用digest()
方法生成消息摘要,MessageDigest
类此方法计算当前对象的散列函数,并以字节数组的形式返回消息摘要。
使用摘要方法生成消息摘要。
MessageDigest md = MessageDigest.getInstance("SHA-256");
md.update(msg.getBytes());
byte[] digest = md.digest();
示例代码
以下是从文件中读取数据并生成消息摘要并打印出来的示例。
import java.security.MessageDigest;
import java.util.Scanner;
public class MessageDigestExample {
public static void main(String args[]) throws Exception{
//Reading data from user
Scanner sc = new Scanner(System.in);
System.out.println("Enter the message");
String message = sc.nextLine();
//Creating the MessageDigest object
MessageDigest md = MessageDigest.getInstance("SHA-256");
//Passing data to the created MessageDigest Object
md.update(message.getBytes());
//Compute the message digest
byte[] digest = md.digest();
System.out.println(digest);
//Converting the byte array in to HexString format
StringBuffer hexString = new StringBuffer();
for (int i = 0;i<digest.length;i++) {
hexString.append(Integer.toHexString(0xFF & digest[i]));
}
System.out.println("Hex format : " + hexString.toString());
}
}
编译并执行上面示例代码,得到以下结果:
Enter the message
Hello how are you
[B@55f96302
Hex format: 2953d33828c395aebe8225236ba4e23fa75e6f13bd881b9056a3295cbd64d3
上一篇:
Java密码学简介
下一篇:
Java密码学创建MAC