Java の RSA 暗号化アルゴリズムを実装する方法

RSAアルゴリズムはJavaの組み込み暗号化ライブラリであるjavax.cryptoを使用してJavaで実装できます。

以下に RSA 暗号化および復号化の簡単なコード例を示します。

import javax.crypto.Cipher;
import java.security.KeyFactory;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;
import java.util.Base64;

public class RSAExample {

    public static void main(String[] args) throws Exception {
        String originalText = "Hello, RSA!";

        // 生成公私密钥对
        KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
        keyPairGenerator.initialize(2048);
        KeyPair keyPair = keyPairGenerator.generateKeyPair();

        PublicKey publicKey = keyPair.getPublic();
        PrivateKey privateKey = keyPair.getPrivate();

        // 使用公钥加密数据
        byte[] encryptedBytes = encrypt(originalText, publicKey);

        // 使用私钥解密数据
        String decryptedText = decrypt(encryptedBytes, privateKey);

        System.out.println("Original Text: " + originalText);
        System.out.println("Encrypted Text: " + Base64.getEncoder().encodeToString(encryptedBytes));
        System.out.println("Decrypted Text: " + decryptedText);
    }

    public static byte[] encrypt(String text, PublicKey publicKey) throws Exception {
        Cipher cipher = Cipher.getInstance("RSA");
        cipher.init(Cipher.ENCRYPT_MODE, publicKey);
        return cipher.doFinal(text.getBytes());
    }

    public static String decrypt(byte[] encryptedBytes, PrivateKey privateKey) throws Exception {
        Cipher cipher = Cipher.getInstance("RSA");
        cipher.init(Cipher.DECRYPT_MODE, privateKey);
        byte[] decryptedBytes = cipher.doFinal(encryptedBytes);
        return new String(decryptedBytes);
    }
}

このサンプルコードでは、最初に2048ビットRSA公開鍵ペアを作成し、公開鍵を使用して元のテキストを暗号化、次に秘密鍵を使用して暗号化されたデータを復号化します。最後に、元のテキスト、暗号化されたテキスト、復号化されたテキストを出力します。

ただし、ここでは暗号化されたテキストを文字列として出力するためにBase64エンコーディングを使用していますが、これは視覚的にわかりやすくするためのものです。実際の使用では、暗号化されたデータを格納したり移動したりするための適切な方法を必要に応じて選択できます。

bannerAds