Java 实现 RSA 非对称加密
RSA 加解密
RSA是一种非对称加密算法,拥有一对密钥(公钥和私钥),由公钥加密的数据只能由私钥解密,由私钥加密的数据只能由公钥解密。
RSA 工具类
public class RsaUtils {
//加密算法RSA
private static final String ALGORITHM = "RSA";
//密钥长度
private static final int KEY_SIZE = 1024;
//公钥文件
private static final String PUBLIC_KEY_FILE = "PublicKey";
//密钥文件
private static final String PRIVATE_KEY_FILE = "PrivateKey";
/**
* @Title: generateKeyPair
* @Description: TODO(生成并保存密钥对)
* @author mervyn
* @date 2020年05月21日 10:59:07
* @param
* @return void
* @throws
*/
public static void generateKeyPair() {
//获取一个RSA算法的密钥生成实例
KeyPairGenerator keyPairGenerator = null;
try {
keyPairGenerator = KeyPairGenerator.getInstance(ALGORITHM);
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
//初始化密钥长度
keyPairGenerator.initialize(KEY_SIZE);
//生成密钥对
KeyPair keyPair = keyPairGenerator.generateKeyPair();
//公钥
RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic();
//私钥
RSAPrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate();
//编码处理,方便保存
String publicKeyStr = new BASE64Encoder().encode(publicKey.getEncoded());
String privateKeyStr = new BASE64Encoder().encode(privateKey.getEncoded());
//保存输出流
BufferedWriter pubBw = null;
BufferedWriter priBw = null;
try {
pubBw = new BufferedWriter(new FileWriter(PUBLIC_KEY_FILE));
priBw = new BufferedWriter(new FileWriter(PRIVATE_KEY_FILE));
pubBw.write(publicKeyStr);
priBw.write(privateKeyStr);
pubBw.flush();
priBw.flush();
} catch (IOException e) {
e.printStackTrace();
} finally {
if (pubBw != null) {
try {
pubBw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
if (priBw != null) {
try {
priBw.close();
} catch