"Enter"a basıp içeriğe geçin

RSA Nedir ?

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

Bir yanıt yazın

E-posta adresiniz yayınlanmayacak. Gerekli alanlar * ile işaretlenmişlerdir