Kryptografia Java - KeyGenerator

Java zapewnia KeyGenerator class ta klasa jest używana do generowania kluczy tajnych, a obiekty tej klasy są wielokrotnego użytku.

Aby wygenerować klucze za pomocą klasy KeyGenerator, wykonaj kroki podane poniżej.

Krok 1: Utwórz obiekt KeyGenerator

Plik KeyGenerator klasa zapewnia getInstance() , która akceptuje zmienną String reprezentującą wymagany algorytm generowania kluczy i zwraca obiekt KeyGenerator, który generuje klucze tajne.

Stwórz KeyGenerator obiekt za pomocą getInstance() metoda, jak pokazano poniżej.

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

Krok 2: Utwórz obiekt SecureRandom

Plik SecureRandom klasa java.Securitypakiet zapewnia silny generator liczb losowych, który jest używany do generowania liczb losowych w Javie. Utwórz wystąpienie tej klasy, jak pokazano poniżej.

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

Krok 3: Zainicjuj KeyGenerator

Plik KeyGenerator class udostępnia metodę o nazwie init() ta metoda akceptuje obiekt SecureRandom i inicjuje bieżącą KeyGenerator.

Zainicjuj obiekt KeyGenerator utworzony w poprzednim kroku przy użyciu init() metoda.

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

Przykład

Poniższy przykład ilustruje generowanie klucza tajnego klucza przy użyciu klasy KeyGenerator klasy javax.crypto pakiet.

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);      
   }
}

Wynik

Powyższy program generuje następujące dane wyjściowe -

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