RSA公钥加密
public static String encrypt2(String data, String publicKeyString) throws Exception {
byte[] dataBytes = data.getBytes("GB2312"); // 使用 GB2312 编码
//byte[] dataBytes = data.getBytes("UTF-8"); // 使用 UTF-8 编码
// 将Base64编码的公钥字符串转换为 PublicKey 对象
byte[] publicKeyBytes = Base64.decode(publicKeyString, Base64.DEFAULT);
X509EncodedKeySpec keySpec = new X509EncodedKeySpec(publicKeyBytes);
KeyFactory keyFactory = KeyFactory.getInstance("RSA");
PublicKey publicKey = keyFactory.generatePublic(keySpec);
// 使用公钥初始化 Cipher 对象
Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
// 执行加密操作
byte[] encryptedBytes = cipher.doFinal(dataBytes);
// 将加密结果进行Base64编码并返回
return Base64.encodeToString(encryptedBytes, Base64.DEFAULT);
}
如果报错,是你的公钥有问题
公钥请不要加头部“-----BEGIN PUBLIC KEY-----” 和尾部“-----END PUBLIC KEY-----”
直接是中间的密钥也不要加"\n"字符