java jks pkcs_Java PKCS12转JKS

package com.what21.demo07;

import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.security.Key;

import java.security.KeyStore;

import java.security.cert.Certificate;

import java.util.Enumeration;

public class PKCS12ConvertToJKS {

// 证书格式

public static final String PKCS12 = "PKCS12";

public static final String JKS = "JKS";

// 证书和路径

public static final String INPUT_KEYSTORE_FILE = "c:/mykey.p12";

public static final String KEYSTORE_PASSWORD = "12345678";

public static final String OUTPUT_KEYSTORE_FILE = "c:/change.jks";

// 证书别名

public static final String CERT_ALIAS = "change";

/**

* @param args

*/

public static void main(String[] args) throws Exception {

KeyStore inputKeyStore = KeyStore.getInstance(PKCS12);

// 加载P12证书

FileInputStream fis = new FileInputStream(INPUT_KEYSTORE_FILE);

// P12证书密码

char[] nPassword = KEYSTORE_PASSWORD.toCharArray();

inputKeyStore.load(fis, nPassword);

fis.close();

System.out.println("keystore type=" + inputKeyStore.getType());

KeyStore outputKeyStore = KeyStore.getInstance(JKS);

outputKeyStore.load(null, KEYSTORE_PASSWORD.toCharArray());

Enumeration enumStrs = inputKeyStore.aliases();

while (enumStrs.hasMoreElements()) {

String keyAlias = enumStrs.nextElement();

System.out.println("alias=[" + keyAlias + "]");

if (inputKeyStore.isKeyEntry(keyAlias)) {

Key key = inputKeyStore.getKey(keyAlias, nPassword);

Certificate[] certChain = inputKeyStore

.getCertificateChain(keyAlias);

outputKeyStore.setKeyEntry(CERT_ALIAS, key,

KEYSTORE_PASSWORD.toCharArray(), certChain);

}

}

FileOutputStream out = new FileOutputStream(OUTPUT_KEYSTORE_FILE);

outputKeyStore.store(out, nPassword);

out.close();

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值