【SpringBoot】RSA加密(非对称加密)
在Spring Boot中使用RSA非对称加密,你可以使用Java Cryptography Extension (JCE) 提供的类和方法。以下是一个简单的例子,展示了如何生成RSA密钥对,以及如何使用公钥加密和私钥解密。
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import java.util.Base64;
public class RSACrypto {
public static void main(String[] args) throws Exception {
// 生成RSA密钥对
KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
keyPairGenerator.initialize(2048, new SecureRandom());
KeyPair keyPair = keyPairGenerator.generateKeyPair();
// 公钥加密
Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.ENCRYPT_MODE, keyPair.getPublic());
byte[] encryptedBytes = cipher.doFinal("Hello, World!".getBytes());
String encryptedString = Base64.getEncoder().encodeToString(encryptedBytes);
System.out.println("Encrypted: " + encryptedString);
// 私钥解密
cipher.init(Cipher.DECRYPT_MODE, keyPair.getPrivate());
byte[] decryptedBytes = cipher.doFinal(encryptedBytes);
String decryptedString = new String(decryptedBytes);
System.out.println("Decrypted: " + decryptedString);
}
}
在这个例子中,我们首先生成了一个2048位的RSA密钥对。然后使用公钥对字符串"Hello, World!"进行加密,并将加密结果转换为Base64编码的字符串。接着,我们使用私钥对加密过的数据进行解密,并将解密结果转换回字符串。
请注意,这个例子仅用于演示目的,实际应用中应该更安全,例如将密钥存储在安全的地方,不要在代码或配置文件中直接包含密钥,避免硬编码密钥,并考虑使用更高级的加密策略。
评论已关闭