大家好,我是神韵,是一个技术&生活博主。出文章目的主要是两个,一是好记忆不如烂笔头,记录总结中提高自己。二是希望我的文章可以帮到大家。欢迎大家留言讨论,你们的行动将是我无限的动力。
本篇主题是:使用Java代码生成RSA公私钥的.pem文件
上一篇文章介绍妙用了Git自带的OpenSSL生成RSA公私钥的.pem文件,这篇文章讲简单介绍用代码生成RSA公私钥的.pem文件。废话不多说,下面直接亮代码
package pers.xue.encrypt.rsa;import lombok.extern.slf4j.Slf4j;
import org.bouncycastle.util.io.pem.PemObject;
import org.bouncycastle.util.io.pem.PemWriter;import java.io.FileWriter;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.NoSuchAlgorithmException;/*** @author huangzhixue* @date 2022/11/15 09:55* @Description* refer to https://www.baeldung.com/java-rsa*/
@Slf4j
public class GeneratePemPariKeyFile {private static final String pairKeyDirectory = "src/main/resources/rsa";private static final String publicKeyPath = "src/main/resources/rsa/rsaPublicKey.pem";/*** 上面已经创建了src/main/resources/rsa,这里可以用全称,然后通过Paths.get去创建rsaPrivateKey.pem文件*/private static final String privateKeyPath = "src/main/resources/rsa/rsaPrivateKey.pem";private static final String publicKeyPrefix = "PUBLIC KEY";private static final String privateKeyPrefix = "PRIVATE KEY";public static void generatePublicKeyPemFile() throws NoSuchAlgorithmException, IOException {// algorithm 指定算法为RSAKeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");// 指定密钥长度为2048keyPairGenerator.initialize(2048);// 生成密钥KeyPair keyPair = keyPairGenerator.generateKeyPair();// 文件夹不存在,则先创建Files.createDirectories(Paths.get(pairKeyDirectory));try(FileWriter priFileWriter = new FileWriter(privateKeyPath);PemWriter priPemWriter = new PemWriter(priFileWriter);FileWriter pubFileWriter = new FileWriter(publicKeyPath);PemWriter pubPemWriter = new PemWriter(pubFileWriter)) {priPemWriter.writeObject(new PemObject(privateKeyPrefix, keyPair.getPrivate().getEncoded()));pubPemWriter.writeObject(new PemObject(publicKeyPrefix, keyPair.getPublic().getEncoded()));} catch (IOException e) {log.error("generate pem file fail", e);}}public static void main(String[] args) throws NoSuchAlgorithmException, IOException {generatePublicKeyPemFile();}
}
代码首先通过KeyPairGenerator指定algorithm为RSA,长度为2048,生成长度为48的RSA密钥。然后通过PemWriter这个类来写出PemObject文件
其它代码都是文件输出的基础,这里不再介绍。
需要注意的点,这里必须指定为PUBLIC KEY 而不是RSA PUBLIC KEY,后果指定后者,后续使用可能会出现错误,比如转Jwt时会报序列错误,这里简单提一下。
最后会在资源目录下生成两个pem文件,如下所示