• 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、使用

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

    具体代码略...

  • 相关阅读:
    加壳技术
    1002 ( A + B Problem II )
    1000 ( A + B Problem )
    1001 ( Sum Problem )
    背单词Delphi版
    覆盖Form.WndProc来响应消息
    覆盖Dispatch响应消息
    美丽人生论坛看贴工具delphi版
    TWebBrowser组件在DELPHI中POST数据和取得网页源文件
    读淘宝商品描述页源码delphi版
  • 原文地址:https://www.cnblogs.com/huahua035/p/8125311.html
Copyright © 2020-2023  润新知