web-dev-qa-db-ja.com

pkcs12証明書情報の読み取り

証明書情報の読み取りに問題があります。 Java bouncycastleライブラリとAndroidをプログラムで使用して)を使用して完全な情報を読みたい。今、コンソールでkeytoolコマンドを使用している:

>keytool -list -keystore 1.p12 -storetype pkcs12 -v

助言がありますか?

13
ilya.stmn

私は解決策を見つけました。主なアイデアは、証明書をx509にキャストし、次にSubjectDNを取得して値を解析することです。

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

        KeyStore p12 = KeyStore.getInstance("pkcs12");
        p12.load(new FileInputStream("pkcs.p12"), "password".toCharArray());
        Enumeration<String> e = p12.aliases();
        while (e.hasMoreElements()) {
            String alias = e.nextElement();
            X509Certificate c = (X509Certificate) p12.getCertificate(alias);
            Principal subject = c.getSubjectDN();
            String subjectArray[] = subject.toString().split(",");
            for (String s : subjectArray) {
                String[] str = s.trim().split("=");
                String key = str[0];
                String value = str[1];
                System.out.println(key + " - " + value);
            }
        }
    }
}
46
ilya.stmn