共計 1619 個字符,預計需要花費 5 分鐘才能閱讀完成。
要在 Java 中實現 RSA 加密和解密文件,可以使用 Java Cryptography Architecture(JCA)提供的 RSA 算法。以下是一個簡單的示例代碼,用于加密和解密文件。
- 導入必要的類和包:
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;
- 添加 Bouncy Castle 作為 JCA 的提供者:
Security.addProvider(new BouncyCastleProvider());
- 生成 RSA 密鑰對:
KeyPairGenerator keyGen = KeyPairGenerator.getInstance("RSA", "BC");
keyGen.initialize(2048);
KeyPair keyPair = keyGen.generateKeyPair();
PrivateKey privateKey = keyPair.getPrivate();
PublicKey publicKey = keyPair.getPublic();
- 加密文件:
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);
}
- 解密文件:
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);
}
請注意,上述代碼使用 Bouncy Castle 作為 JCA 的提供者,并假設輸入文件名為 "input.txt",加密后的文件名為 "encrypted.txt",解密后的文件名為 "decrypted.txt"。此外,還假設輸入文件不超過 245 個字節,加密后的文件長度為 256 個字節。您可以根據實際需要進行修改。
丸趣 TV 網 – 提供最優質的資源集合!
正文完