在Java中实现RSA加解密,可以使用Java自带的java.security包中的类,主要是KeyPairGenerator、KeyPair、PrivateKey、PublicKey以及Cipher。
下面是一个简单的RSA加解密工具类示例:
import javax.crypto.Cipher;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.spec.RSAPublicKeySpec;
import java.util.Base64;
public class RSAUtil {
private static final String RSA = "RSA";
/**
* 生成RSA密钥对
* @param keySize 密钥长度,如1024, 2048
* @return KeyPair
*/
public static KeyPair generateKeyPair(int keySize) throws Exception {
KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance(RSA);
keyPairGenerator.initialize(keySize);
return keyPairGenerator.generateKeyPair();
}
/**
* 使用公钥加密
* @param data 明文数据
* @param publicKey 公钥
* @return Base64编码的密文
*/
public static String encrypt(String data, PublicKey publicKey) throws Exception {
Cipher cipher = Cipher.getInstance(RSA);
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
byte[] encryptedBytes = cipher.doFinal(data.getBytes());
return Base64.getEncoder().encodeToString(encryptedBytes);
}
/**
* 使用私钥解密
* @param encryptedData Base64编码的密文
* @param privateKey 私钥
* @return 解密后的明文
*/
public static String decrypt(String encryptedData, PrivateKey privateKey) throws Exception {
Cipher cipher = Cipher.getInstance(RSA);
cipher.init(Cipher.DECRYPT_MODE, privateKey);
byte[] encryptedBytes = Base64.getDecoder().decode(encryptedData);
byte[] decryptedBytes = cipher.doFinal(encryptedBytes);
return new String(decryptedBytes);
}
public static void main(String[] args) throws Exception {
// 生成密钥对
KeyPair keyPair = generateKeyPair(2048);
PublicKey publicKey = keyPair.getPublic();
PrivateKey privateKey = keyPair.getPrivate();
// 测试加密解密
String originalText = "Hello, RSA!";
String encryptedText = encrypt(originalText, publicKey);
System.out.println("Encrypted: " + encryptedText);
String decryptedText = decrypt(encryptedText, privateKey);
System.out.println("Decrypted: " + decryptedText);
}
}
这个工具类提供了生成RSA密钥对、使用公钥加密、使用私钥解密的方法。
注意,RSA加密解密适合小数据量的加解密,因为其性能较慢,对于大量数据通常会结合对称加密算法使用。
此外,实际应用中密钥的存储和传输应确保安全性。