== Grundlagen ==
Das wichtigste Paket von JAVA, dass man bei allen JAVA – Operationen benötigt, ist das „java.security.“ - Standard Paket. Dies ist, nach dem man JAVA installiert hat normalerweise vorhanden.
Als erstes, möchte ich einen normalen Key – Generator erklären. Andere Versionen sind im Internet vorhanden wie z.B. auf → codeplanet.eu/
Die maximale Schlüsselgröße ist 2048 Bit, diese ist aber auf Grund der starken Richtlinien – Zuständigkeit in JAVA 2 SDK begrenzt. Weitere Informationen zu diesem Thema, wieder im Netz oder direkt unter → oracle.com/technetwork/java/index.html
Es gibt aber auch ein Prüfungsverfahren, welches ohne Bedingung heruntergeladen werden kann. Dies ist bei JAVA Cryptography Extension kurz JCE auch wieder unter → oracle.com/technetwork/java/index.html erhältlich.
So kann man nun einen 8192 Bit RSA Key erstellen.
== Code für den Generator ==
Alles anzeigen
== Kompilieren ==
Jetzt muss dieser Code kompiliert und in der Befehlszeile ausgeführt werden. Wenn man zum exportieren eine .jar – Datei wählt, muss man java -jar binary.jar ausführen. Nachdem man diesen Code ausgeführt hat, sind zwei neue Dateien im aktuellen Verzeichnis entstanden.
1. Datei = "RSA_private.key"
2. Datei = "RSA_public.key"
Diese beiden Dateien, werden mit einer Schlüsselgröße von 8192 Bits hergestellt. So wie sie entstanden sind, sind diese auch schon bereit und können genutzt werden.
Der Public – Key wird zum Verschlüsseln benutzt und der Private – Key zum Entschlüsseln von ausgewählten Dateien.
== Quellen: ==
de.wikipedia.org/wiki/RSA-Kryptosystem
codeplanet.eu/
oracle.com/
oracle.com/technetwork/java/index.html
de.wikipedia.org/wiki/Asymmetrisches_Kryptosystem
de.wikipedia.org/wiki/Symmetrisches_Kryptosystem
== Weiteres zu diesem Thema ==
Vielleicht interessiert sich der Eine oder Andere für dieses Thema und hätte gerne Weiteres zum Thema Verschlüsselungen und Entschlüsselungen bezogen auf dieses Thema, kann ich nach Verlangen zusammenschreiben und hier ablegen oder per email zukommen lassen. Oder einfach mal hier → http://www.codeplanet.eu/tutorials/java/…sa-in-java.html
hinein schnuppern.
MfG >>>spaceher0<<<
Das wichtigste Paket von JAVA, dass man bei allen JAVA – Operationen benötigt, ist das „java.security.“ - Standard Paket. Dies ist, nach dem man JAVA installiert hat normalerweise vorhanden.
Als erstes, möchte ich einen normalen Key – Generator erklären. Andere Versionen sind im Internet vorhanden wie z.B. auf → codeplanet.eu/
Die maximale Schlüsselgröße ist 2048 Bit, diese ist aber auf Grund der starken Richtlinien – Zuständigkeit in JAVA 2 SDK begrenzt. Weitere Informationen zu diesem Thema, wieder im Netz oder direkt unter → oracle.com/technetwork/java/index.html
Es gibt aber auch ein Prüfungsverfahren, welches ohne Bedingung heruntergeladen werden kann. Dies ist bei JAVA Cryptography Extension kurz JCE auch wieder unter → oracle.com/technetwork/java/index.html erhältlich.
So kann man nun einen 8192 Bit RSA Key erstellen.
== Code für den Generator ==
Quellcode
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.io.ObjectOutputStream;
- import java.security.GeneralSecurityException;
- import java.security.KeyPair;
- import java.security.KeyPairGenerator;
- import java.security.SecureRandom;
- public class RSAKeyGenerator {
- private static final int KEYSIZE = 8192 //KEYSIZE = 8192 -> Schlüsselgröße in Bits
- public static void main(String[] args) {
- generateKey("RSA_private.key","RSA_public.key"); //generierte Dateien
- }
- public static void generateKey(String privateKey, String publicKey) {
- try {
- KeyPairGenerator pairgen = KeyPairGenerator.getInstance("RSA");
- SecureRandom random = new SecureRandom();
- pairgen.initialize(KEYSIZE, random);
- KeyPair keyPair = pairgen.generateKeyPair();
- ObjectOutputStream out = new ObjectOutourStream(new FileOutputStream(publicKey));
- out.writeObject(key.Pair.getPublic());
- out.close();
- out = new ObjectOutputStream(new FileOutputStream(privateKey));
- out.writeObject(keyPair.getPublic());
- out.close();
- } catch (IOException e) {
- System.err.printIn(e);
- } catch (GeneralSecurityException e) {
- System.err.printIn(e);
- }
- }
- }
== Kompilieren ==
Jetzt muss dieser Code kompiliert und in der Befehlszeile ausgeführt werden. Wenn man zum exportieren eine .jar – Datei wählt, muss man java -jar binary.jar ausführen. Nachdem man diesen Code ausgeführt hat, sind zwei neue Dateien im aktuellen Verzeichnis entstanden.
1. Datei = "RSA_private.key"
2. Datei = "RSA_public.key"
Diese beiden Dateien, werden mit einer Schlüsselgröße von 8192 Bits hergestellt. So wie sie entstanden sind, sind diese auch schon bereit und können genutzt werden.
Der Public – Key wird zum Verschlüsseln benutzt und der Private – Key zum Entschlüsseln von ausgewählten Dateien.
== Quellen: ==
de.wikipedia.org/wiki/RSA-Kryptosystem
codeplanet.eu/
oracle.com/
oracle.com/technetwork/java/index.html
de.wikipedia.org/wiki/Asymmetrisches_Kryptosystem
de.wikipedia.org/wiki/Symmetrisches_Kryptosystem
== Weiteres zu diesem Thema ==
Vielleicht interessiert sich der Eine oder Andere für dieses Thema und hätte gerne Weiteres zum Thema Verschlüsselungen und Entschlüsselungen bezogen auf dieses Thema, kann ich nach Verlangen zusammenschreiben und hier ablegen oder per email zukommen lassen. Oder einfach mal hier → http://www.codeplanet.eu/tutorials/java/…sa-in-java.html
hinein schnuppern.
MfG >>>spaceher0<<<
17.574 mal gelesen