Java密碼學創建MAC

MAC(消息認證碼)算法是一種對稱密鑰加密技術,用於提供消息認證。要建立MAC過程,發送方和接收方共享對稱密鑰K。
實質上,MAC是在基礎消息上生成的加密校驗和,它與消息一起發送以確保消息驗證。

使用MAC進行身份驗證的過程如下圖所示 -
Java密碼學創建MAC

在Java中,javax.crypto包的Mac類提供了消息認證代碼的功能。按照以下步驟使用此類創建消息身份驗證代碼。

第1步:創建KeyGenerator對象

KeyGenerator類提供getInstance()方法,該方法接受表示所需密鑰生成算法的String變量,並返回生成密鑰的KeyGenerator對象。

使用getInstance()方法創建KeyGenerator對象,如下所示。

//Creating a KeyGenerator object
KeyGenerator keyGen = KeyGenerator.getInstance("DES");

第2步:創建SecureRandom對象

java.Security包的SecureRandom類提供了一個強大的隨機數生成器,用於在Java中生成隨機數。 實例化此類,如下所示。

//Creating a SecureRandom object
SecureRandom secRandom = new SecureRandom();

第3步:初始化KeyGenerator

KeyGenerator類提供了一個名爲init()的方法,此方法接受SecureRandom對象並初始化當前的KeyGenerator

使用此方法初始化在上一步中創建的KeyGenerator對象。

//Initializing the KeyGenerator
keyGen.init(secRandom);

第4步:生成密鑰

使用KeyGenerator類的generateKey()方法生成密鑰,如下所示。

//Creating/Generating a key
Key key = keyGen.generateKey();

第5步:初始化Mac對象

Mac類的init()方法接受Key對象並使用給定的鍵初始化當前的Mac對象。

//Initializing the Mac object
mac.init(key);

第6步:完成mac操作

Mac類的doFinal()方法用於完成Mac操作。 將所需的數據以字節數組的形式傳遞給此方法,並完成操作,如下所示。

//Computing the Mac
String msg = new String("Hi how are you");
byte[] bytes = msg.getBytes();
byte[] macResult = mac.doFinal(bytes);

示例
以下示例演示如何使用JCA生成消息驗證代碼(MAC)。 在這裏,將收到一條簡單的消息「Hi how are you」,併爲該消息生成一個Mac。

import java.security.Key;
import java.security.SecureRandom;

import javax.crypto.KeyGenerator;
import javax.crypto.Mac;

public class MacSample {
   public static void main(String args[]) throws Exception{
      //Creating a KeyGenerator object
      KeyGenerator keyGen = KeyGenerator.getInstance("DES");

      //Creating a SecureRandom object
      SecureRandom secRandom = new SecureRandom();

      //Initializing the KeyGenerator
      keyGen.init(secRandom);

      //Creating/Generating a key
      Key key = keyGen.generateKey();     

      //Creating a Mac object
      Mac mac = Mac.getInstance("HmacSHA256");

      //Initializing the Mac object
      mac.init(key);

      //Computing the Mac
      String msg = new String("Hi how are you");
      byte[] bytes = msg.getBytes();      
      byte[] macResult = mac.doFinal(bytes);

      System.out.println("Mac result:");
      System.out.println(new String(macResult));     
   }
}

上述程序將生成以下輸出 -

Mac result:
HÖ„^ǃÎ_Utbh…?š_üzØSSÜh_ž_œa0ŽV?