java 解析p12证书 (获取公钥、私钥、序列号)

文章讲述了如何使用Java解析PKCS12格式的证书文件,包括获取公钥、私钥和证书序列号的过程,以P12Utils类为例,展示了在测试环境中操作apiclient_cert.p12文件的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

          

1. p12文件放在resources目录下


2. P12InfoVo

import lombok.Builder;
import lombok.Data;

import java.io.Serializable;
import java.security.PrivateKey;
import java.security.PublicKey;


/**
 * p12证书VO
 */
@Data
@Builder
public class P12InfoVo implements Serializable{

    /**
     * 证书公钥
     */
    private final PublicKey publicKey;

    /**
     * 证书私钥
     */
    private final PrivateKey privateKey;

    /**
     * 证书序列号
     */
    private final String serialNo;
}

3. P12Utils

import com.ruoyi.ruoyils.utils.WxPayUtils;
import org.junit.Test;
import sun.security.x509.X509CertImpl;
import java.io.FileInputStream;
import java.math.BigInteger;
import java.security.KeyStore;
import java.security.PrivateKey;
import java.security.cert.Certificate;
import java.util.Enumeration;


/**
 *
 * PKCS12证书中解析公钥、私钥、证书序列号
 *
 * apiclient_cert.p12
 *
 */
public class P12Utils {


    @Test
    public void test(){
        // p12证书路径
        String path = "D:\\Java\\work\\ChenXinCode\\light_show\\ruoyi-admin\\src\\main\\resources\\apiclient_cert.p12";
        P12InfoVo vo = this.parse(path, WxPayUtils.mchId);

        System.out.println("证书公钥: " + vo.getPublicKey());
        System.out.println("证书私钥: " + vo.getPrivateKey());
        System.out.println("证书序列号: " + vo.getSerialNo());
    }

    /**
     * 解析p12文件
     *
     * @param p12Path   证书文件路径
     * @param passwd    证书密码 (也就是商户号)
     * @return
     */
    public static P12InfoVo parse(String p12Path, String passwd) {
        try {
            // 获取文件流
            FileInputStream is = new FileInputStream(p12Path);

            KeyStore ks = KeyStore.getInstance("PKCS12");
            ks.load(is, passwd.toCharArray());
            String keyAlias = null;
            //解析证书,必须有别名
            Enumeration<String> aliases = ks.aliases();
            if (aliases.hasMoreElements()) {
                keyAlias = aliases.nextElement();
            }
            //解析私钥
            PrivateKey privateKey = (PrivateKey) ks.getKey(keyAlias, passwd.toCharArray());
            Certificate cert = ks.getCertificate(keyAlias);
            BigInteger serialNumber = ((X509CertImpl) cert).getSerialNumber();
            //证书一般都使用16进制表示
            String certSn = serialNumber.toString(16).toUpperCase();

            //设置证书公钥、私钥、序列号
            return P12InfoVo.builder()
                    .publicKey(cert.getPublicKey())
                    .privateKey(privateKey)
                    .serialNo(certSn)
                    .build();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }
}

Java中,读取.cer (证书) 或.pfx (个人信息交换文件) 文件获取其中的公钥私钥,通常需要使用`KeyStore`和`Certificate`类,以及`java.security`包下的工具。以下是基本步骤: 1. **加载keystore**: 使用`KeyStore.getInstance()`方法加载keystore,提供正确的类型(如JKS、PKCS12等)和文件路径。 ```java KeyStore keyStore = KeyStore.getInstance("PKCS12"); InputStream in = new FileInputStream("path_to_your_pfx_file.pfx"); keyStore.load(in, "password".toCharArray()); ``` 2. **获取证书链**: 使用`keyStore.getCertificateChain(certAlias)`获取包含证书的链,`certAlias`是证书别名。 3. **获取信任管理器**: 创建`TrustManagerFactory`,然后从keystore中获取`X509TrustManager`。 ```java TrustManagerFactory trustManagerFactory = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm()); trustManagerFactory.init(keyStore); TrustManager[] trustManagers = trustManagerFactory.getTrustManagers(); ``` 4. **获取公钥私钥**: 对于.cer文件证书中通常包含公钥,而.pfx还包含了私钥。如果仅需公钥,可以遍历证书链,每个证书都有公开的`getPublicKey()`方法。如果需要私钥,你需要创建`KeyPairGenerator`,并通过`Certificate`对象的`getPrivateKey()`方法得到。 ```java for (Certificate cert : chain) { PublicKey publicKey = cert.getPublicKey(); // 对于PFX,还需处理PrivateKey } ``` 请注意,`.pfx`文件中可能有多个key entry,每个entry对应一对公钥私钥。操作时需要确定所需的密钥对。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

stjl.xyz

谢谢打赏,祝老板心想事成

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值