RSA (Rivest-Shamir-Adleman), adını geliştiricilerinden alan ve günümüzde en yaygın kullanılan asimetrik şifreleme algoritmalarından biridir. RSA’da iki anahtar kullanılır:
- Açık Anahtar (Public Key): Şifreleme ve doğrulama için kullanılır, herkesle paylaşılabilir.
- Özel Anahtar (Private Key): Şifre çözme ve imzalama için kullanılır, gizli tutulur.
Bu anahtar çiftleri, büyük asal sayıların matematiksel ilişkilerine dayanmaktadır.
Avantajlar:
- Güçlü bir güvenlik sağlar.
- Açık ve özel anahtar ayrımı ile anahtar yönetimi kolaydır.
- Dijital imza ve şifreleme işlemlerini aynı anda yapabilir.
Dezavantajlar:
- Simetrik algoritmalara göre çok daha yavaştır.
- Kuantum bilgisayarların yaygınlaşması durumunda güvenliği tehlikeye girebilir.
Java kodunda RSA ile ilgili kısa bir şifreleme örneğini aşağıda görebilirsiniz.
import java.security.*;
import javax.crypto.Cipher;
import java.util.Base64;
public class RSAOperation{
// Anahtar çiftlerini oluşturma
public static KeyPair generateKeyPair() throws Exception {
KeyPairGenerator keyGen = KeyPairGenerator.getInstance("RSA");
keyGen.initialize(2048); // 2048 bitlik anahtar uzunluğu
return keyGen.generateKeyPair();
}
// Veriyi şifreleme
public static String encrypt(String plainText, PublicKey publicKey) throws Exception {
Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
byte[] encryptedBytes = cipher.doFinal(plainText.getBytes());
return Base64.getEncoder().encodeToString(encryptedBytes);
}
// Veriyi çözme
public static String decrypt(String encryptedText, PrivateKey privateKey) throws Exception {
Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.DECRYPT_MODE, privateKey);
byte[] decryptedBytes = cipher.doFinal(Base64.getDecoder().decode(encryptedText));
return new String(decryptedBytes);
}
public static void main(String[] args) {
try {
// Anahtarları oluştur
KeyPair keyPair = generateKeyPair();
PublicKey publicKey = keyPair.getPublic();
PrivateKey privateKey = keyPair.getPrivate();
// Şifrelenecek metin
String originalText = "Hello World!";
System.out.println("Original Text: " + originalText);
// Şifreleme
String encryptedText = encrypt(originalText, publicKey);
System.out.println("Encrypted Text: " + encryptedText);
// Şifre çözme
String decryptedText = decrypt(encryptedText, privateKey);
System.out.println("Decrypted Text: " + decryptedText);
} catch (Exception e) {
e.printStackTrace();
}
}
}