Java提供了一個名稱為KeyGenerator
的類,該類用於生成金鑰,此類的物件是可重用的。
要使用KeyGenerator
類生成金鑰,請按照以下步驟操作。
KeyGenerator
類提供getInstance()
方法,該方法接受表示所需金鑰生成演算法的String變數,並返回生成金鑰的KeyGenerator
物件。
使用getInstance()
方法建立KeyGenerator
物件,如下所示。
//Creating a KeyGenerator object
KeyGenerator keyGen = KeyGenerator.getInstance("DES");
java.Security
包的SecureRandom
類提供了一個強大的亂數生成器,用於在Java中生成亂數。 範例化此類,如下所示。
//Creating a SecureRandom object
SecureRandom secRandom = new SecureRandom();
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