Java密碼學KeyGenerator類


Java提供了一個名稱為KeyGenerator的類,該類用於生成金鑰,此類的物件是可重用的。

要使用KeyGenerator類生成金鑰,請按照以下步驟操作。

第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

使用init()方法初始化在上一步中建立的KeyGenerator物件。

//Creating a SecureRandom object
SecureRandom secRandom = new SecureRandom();
//Initializing the KeyGenerator
keyGen.init(secRandom);

範例
下面的範例演示了使用javax.crypto包的KeyGenerator類生成金鑰。

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;

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

public class KeyGeneratorExample {
   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();

      System.out.println(key);      
      Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");      
      cipher.init(cipher.ENCRYPT_MODE, key);      

      String msg = new String("Hi how are you");
      byte[] bytes = cipher.doFinal(msg.getBytes());      
      System.out.println(bytes);      
   }
}

執行上面範例程式碼,得到以下結果:

com.sun.crypto.provider.DESKey@18629
[B@2ac1fdc4