Java密碼學資訊摘要

散列函數非常有用,幾乎出現在所有資訊安全應用程式中。

哈希函數是將數字輸入值轉換為另一個壓縮數值的數學函數。 散列函數的輸入具有任意長度,但輸出始終具有固定長度。

散列函數返回的值稱為資訊摘要或簡稱散列值。 下圖說明瞭散列函數。

Java提供了一個名為MessageDigest的類,它屬於java.security包。 此類支持諸如SHA-1SHA 256MD5演算法之類的演算法,以將任意長度的消息轉換為資訊摘要。

要將給定郵件轉換為郵件摘要,請按照以下步驟進行操作 -

第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