JavaでRSAによるファイルの暗号化と復号化を実行する方法

RSA暗号化と復号化をJavaで実装するには、Java Cryptography Architecture(JCA)によるRSAアルゴリズムを利用できます。以下にファイルの暗号化と復号化のための簡単なサンプルコードを紹介します。

  1. 必要なクラスとパッケージをインポートします。
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.security.Key;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.Security;
import javax.crypto.Cipher;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
  1. JCAプロバイダとしてBouncy Castleを追加する
Security.addProvider(new BouncyCastleProvider());
  1. RSA秘密鍵ペア生成
KeyPairGenerator keyGen = KeyPairGenerator.getInstance("RSA", "BC");
keyGen.initialize(2048);
KeyPair keyPair = keyGen.generateKeyPair();
PrivateKey privateKey = keyPair.getPrivate();
PublicKey publicKey = keyPair.getPublic();
  1. 暗号化したファイル
Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding", "BC");
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
FileInputStream inputFile = new FileInputStream("input.txt");
FileOutputStream outputFile = new FileOutputStream("encrypted.txt");
byte[] inputBytes = new byte[245];
int bytesRead;
while ((bytesRead = inputFile.read(inputBytes)) != -1) {
    byte[] outputBytes = cipher.doFinal(inputBytes, 0, bytesRead);
    outputFile.write(outputBytes);
}
  1. 文書の解読:
cipher.init(Cipher.DECRYPT_MODE, privateKey);
inputFile = new FileInputStream("encrypted.txt");
outputFile = new FileOutputStream("decrypted.txt");
byte[] encryptedBytes = new byte[256];
while ((bytesRead = inputFile.read(encryptedBytes)) != -1) {
    byte[] decryptedBytes = cipher.doFinal(encryptedBytes, 0, bytesRead);
    outputFile.write(decryptedBytes);
}

上掲のコードでは、JCAプロバイダとしてBouncy Castleを使用しており、入力ファイルのファイル名は「input.txt」、暗号化されたファイルのファイル名は「encrypted.txt」、復号化されたファイルのファイル名は「decrypted.txt」を使用しています。また、入力ファイルのサイズは245バイト以下、暗号化されたファイルのサイズは256バイトで固定しています。必要に応じて、修正してください。

bannerAds