zoukankan      html  css  js  c++  java
  • java读取pfx或P12格式的个人交换库公私钥

    使用的是CFCA签发的用于银行间交换数据的证书,下载后直接添加到浏览器中

    1、导出

    从浏览器导出p12文件(包含私钥)

    2、验证

    两种方式:

    openssl

    代码(请注意alias别名是如何获取的):

    package com.shengpay.mas.demo.cert;
    
    import org.apache.commons.codec.binary.Base64;
    
    import java.io.FileInputStream;
    import java.io.FileNotFoundException;
    import java.io.IOException;
    import java.security.*;
    import java.security.cert.*;
    import java.security.cert.Certificate;
    import java.util.Enumeration;
    
    /**
     * Description: 读取P12格式的个人交换库
     * <p>
     * User: lishaohua
     * Date: 2017/12/27  12:51
     */
    public class P12Demo {
    
        public static void main(String[] args) throws KeyStoreException, IOException, CertificateException, NoSuchAlgorithmException, UnrecoverableKeyException {
            String keyStorePath = "D:/123456.pfx";
            String password = "123456";
    
            // 实例化密钥库,默认JKS类型
            KeyStore ks = KeyStore.getInstance("PKCS12");
            // 获得密钥库文件流
            FileInputStream is = new FileInputStream(keyStorePath);
            // 加载密钥库
            ks.load(is, password.toCharArray());
            // 关闭密钥库文件流
            is.close();
    
            //私钥
            Enumeration aliases = ks.aliases();
            String keyAlias = null;
            if (aliases.hasMoreElements()){
                keyAlias = (String)aliases.nextElement();
                System.out.println("p12's alias----->"+keyAlias);
            }
            PrivateKey privateKey = (PrivateKey) ks.getKey(keyAlias, password.toCharArray());
            String privateKeyStr = Base64.encodeBase64String(privateKey.getEncoded());
            System.out.println("私钥------------->" + privateKeyStr);
    
            //公钥
            Certificate certificate = ks.getCertificate(keyAlias);
            String publicKeyStr = Base64.encodeBase64String(certificate.getPublicKey().getEncoded());
            System.out.println("公钥------------->"+publicKeyStr);
        }
    }
    

      

    3、使用

    发布公钥或者双向认证等。

    具体代码略...

  • 相关阅读:
    Solr基础知识二(导入数据)
    Solr基础知识一(安装配置)
    企业微信机器人
    Mysql+Keepalived双主热备高可用操作记录
    mysql互为主从(双主)配置
    编译安装msyql
    JS 常用的一些功能性函数 (自用)
    JavaScrip 之 DOM (回顾)
    MySQL的表定义语法
    MySQL的数据库定义语法
  • 原文地址:https://www.cnblogs.com/huahua035/p/8125311.html
Copyright © 2011-2022 走看看