使用Java代码生成RSA公私钥的.pem文件

  • Post author:
  • Post category:java


大家好,我是神韵,是一个技术&生活博主。出文章目的主要是两个,一是好记忆不如烂笔头,记录总结中提高自己。二是希望我的文章可以帮到大家。欢迎大家留言讨论,你们的行动将是我无限的动力。

本篇主题是:

使用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 指定算法为RSA
        KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
        // 指定密钥长度为2048
        keyPairGenerator.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文件,如下所示



版权声明:本文为qq_41055045原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。