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 Test {
public static final String PKCS12 = "PKCS12";
public static final String JKS = "JKS";
public static final String PFX_KEYSTORE_FILE = "/path/to/pfx/file";//pfx文件位置
public static final String KEYSTORE_PASSWORD = "password_of_pfx";//pfx文件的密码
public static final String JKS_KEYSTORE_FILE = "/path/to/jks/file";//jks文件位置
public static void convertPfxToJks(String pfxFile, String jksFile) {
try {
KeyStore inputKeyStore = KeyStore.getInstance(PKCS12);
FileInputStream fis = new FileInputStream(pfxFile);
char[] nPassword = KEYSTORE_PASSWORD.toCharArray();
inputKeyStore.load(fis, nPassword);
fis.close();
KeyStore outputKeyStore = KeyStore.getInstance(JKS);
outputKeyStore.load(null, nPassword);
Enumeration enums = inputKeyStore.aliases();
while (enums.hasMoreElements()) { // we are readin just one certificate.
String keyAlias = (String) enums.nextElement();
System.out.println("alias=[" + keyAlias + "]");
if (inputKeyStore.isKeyEntry(keyAlias)) {
Key key = inputKeyStore.getKey(keyAlias, nPassword);
Certificate[] certChain = inputKeyStore.getCertificateChain(keyAlias);
outputKeyStore.setKeyEntry(keyAlias, key, nPassword, certChain);
}
}
FileOutputStream out = new FileOutputStream(jksFile);
outputKeyStore.store(out, nPassword);
out.close();
} catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
convertPfxToJks(PFX_KEYSTORE_FILE, JKS_KEYSTORE_FILE);
}
}
转载于:https://my.oschina.net/cashi/blog/800855