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