📜  Java密码学-消息摘要

📅  最后修改于: 2020-11-15 03:43:57             🧑  作者: Mango


哈希函数非常有用,并且几乎出现在所有信息安全应用程序中。

哈希函数是一种数学函数,可将数字输入值转换为另一个压缩数字值。哈希函数的输入为任意长度,但输出始终为固定长度。

哈希函数返回的值称为消息摘要或简称为哈希值。下图说明了哈希函数。

信息摘要

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对象。

md.update(msg.getBytes());

步骤3:生成消息摘要

您可以使用MessageDigest类的digest()方法生成消息摘要,此方法将计算当前对象上的哈希函数,并以字节数组的形式返回消息摘要。

使用摘要方法生成消息摘要。

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

输出

上面的程序生成以下输出-

Enter the message
Hello how are you
[B@55f96302
Hex format: 2953d33828c395aebe8225236ba4e23fa75e6f13bd881b9056a3295cbd64d3