Java-Kryptographie - Daten entschlüsseln

Sie können die verschlüsselten Daten mit der Cipher-Klasse von entschlüsseln javax.cryptoPaket. Führen Sie die folgenden Schritte aus, um bestimmte Daten mit Java zu entschlüsseln.

Schritt 1: Erstellen Sie ein KeyPairGenerator-Objekt

Das KeyPairGenerator Klasse bietet getInstance() Methode, die eine String-Variable akzeptiert, die den erforderlichen Algorithmus zur Schlüsselgenerierung darstellt, und ein KeyPairGenerator-Objekt zurückgibt, das Schlüssel generiert.

Erstellen KeyPairGenerator Objekt mit dem getInstance() Methode wie unten gezeigt.

//Creating KeyPair generator object
KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("DSA");

Schritt 2: Initialisieren Sie das KeyPairGenerator-Objekt

Das KeyPairGenerator Klasse stellt eine Methode mit dem Namen bereit initialize()Diese Methode wird verwendet, um den Schlüsselpaargenerator zu initialisieren. Diese Methode akzeptiert einen ganzzahligen Wert, der die Schlüsselgröße darstellt.

Initialisieren Sie das im vorherigen Schritt erstellte KeyPairGenerator-Objekt mit dem initialize() Methode wie unten gezeigt.

//Initializing the KeyPairGenerator
keyPairGen.initialize(2048);

Schritt 3: Generieren Sie den KeyPairGenerator

Sie können die generieren KeyPair Verwendung der generateKeyPair() Methode der KeyPairGeneratorKlasse. Generieren Sie das Schlüsselpaar mit dieser Methode wie unten gezeigt.

//Generate the pair of keys
KeyPair pair = keyPairGen.generateKeyPair();

Schritt 4: Holen Sie sich den öffentlichen Schlüssel

Sie können den öffentlichen Schlüssel aus dem generierten KeyPair-Objekt mit dem abrufen getPublic() Methode wie unten gezeigt.

//Getting the public key from the key pair
PublicKey publicKey = pair.getPublic();

Schritt 5: Erstellen Sie ein Cipher-Objekt

Das getInstance() Methode von Cipher Die Klasse akzeptiert eine String-Variable, die die erforderliche Transformation darstellt, und gibt ein Cipher-Objekt zurück, das die angegebene Transformation implementiert.

Erstellen Sie das Cipher-Objekt mit dem getInstance() Methode wie unten gezeigt.

//Creating a Cipher object
Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");

Schritt 6: Initialisieren Sie das Cipher-Objekt

Das init() Die Methode der Cipher-Klasse akzeptiert zwei Parameter

  • Ein ganzzahliger Parameter, der den Betriebsmodus darstellt (verschlüsseln / entschlüsseln)
  • Schlüsselobjekt, das den öffentlichen Schlüssel darstellt

Initialisieren Sie das Cypher-Objekt mit init() Methode wie unten gezeigt.

//Initializing a Cipher object
cipher.init(Cipher.ENCRYPT_MODE, publicKey);

Schritt 7: Fügen Sie dem Cipher-Objekt Daten hinzu

Das update() Die Methode der Cipher-Klasse akzeptiert ein Byte-Array, das die zu verschlüsselnden Daten darstellt, und aktualisiert das aktuelle Objekt mit den angegebenen Daten.

Aktualisieren Sie das initialisierte Cipher-Objekt, indem Sie die Daten an das übergeben update() Methode in Form eines Byte-Arrays wie unten gezeigt.

//Adding data to the cipher
byte[] input = "Welcome to Tutorialspoint".getBytes();	  
cipher.update(input);

Schritt 8: Verschlüsseln Sie die Daten

Das doFinal()Die Methode der Cipher-Klasse schließt den Verschlüsselungsvorgang ab. Beenden Sie daher die Verschlüsselung mit dieser Methode wie unten gezeigt.

//Encrypting the data
byte[] cipherText = cipher.doFinal();

Schritt 9: Initialisieren Sie das Cipher-Objekt zur Entschlüsselung

Um den in den vorherigen Schritten verschlüsselten Chiffrier zu entschlüsseln, müssen Sie ihn für die Entschlüsselung initialisieren.

Initialisieren Sie daher das Verschlüsselungsobjekt, indem Sie die Parameter Cipher.DECRYPT_MODE und PrivateKey wie unten gezeigt übergeben.

//Initializing the same cipher for decryption
cipher.init(Cipher.DECRYPT_MODE, pair.getPrivate());

Schritt 10: Entschlüsseln Sie die Daten

Zum Schluss entschlüsseln Sie den verschlüsselten Text mit dem doFinal() Methode wie unten gezeigt.

//Decrypting the text
byte[] decipheredText = cipher.doFinal(cipherText);

Beispiel

Das folgende Java-Programm akzeptiert Text vom Benutzer, verschlüsselt ihn mit dem RSA-Algorithmus und druckt die Verschlüsselung des angegebenen Textes, entschlüsselt die Verschlüsselung und druckt den entschlüsselten Text erneut.

import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.Signature;

import javax.crypto.Cipher;

public class CipherDecrypt {
   public static void main(String args[]) throws Exception{
	   //Creating a Signature object
      Signature sign = Signature.getInstance("SHA256withRSA");
      
      //Creating KeyPair generator object
      KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("RSA");
      
      //Initializing the key pair generator
      keyPairGen.initialize(2048);
      
      //Generate the pair of keys
      KeyPair pair = keyPairGen.generateKeyPair();   
      
      //Getting the public key from the key pair
      PublicKey publicKey = pair.getPublic();  

      //Creating a Cipher object
      Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");

      //Initializing a Cipher object
      cipher.init(Cipher.ENCRYPT_MODE, publicKey);
	  
      //Add data to the cipher
      byte[] input = "Welcome to Tutorialspoint".getBytes();	  
      cipher.update(input);
	  
      //encrypting the data
      byte[] cipherText = cipher.doFinal();	 
      System.out.println( new String(cipherText, "UTF8"));

      //Initializing the same cipher for decryption
      cipher.init(Cipher.DECRYPT_MODE, pair.getPrivate());
      
      //Decrypting the text
      byte[] decipheredText = cipher.doFinal(cipherText);
      System.out.println(new String(decipheredText));
   }
}

Ausgabe

Das obige Programm erzeugt die folgende Ausgabe -

Encrypted Text:
]/[?F3?D?p
v?w?!?H???^?A??????P?u??FA?
?
???_?? ???_jMH-??>??OP?'?j?_?n`
?_??'`????o??_GL??g???g_f?????f|???LT?|?Vz_TDu#??\?<b,,?$C2???Bq?#?lDB`??g,^??K?_?v???`}
?;LX?a?_5e???#???_?6?/B&B_???^?__Ap^#_?q?IEh????_?,??*??]~_?_?D?
_y???lp??a?P_U{

Decrypted Text:
Welcome to Tutorialspoint