証明書情報の読み取りに問題があります。 Java bouncycastleライブラリとAndroidをプログラムで使用して)を使用して完全な情報を読みたい。今、コンソールでkeytoolコマンドを使用している:
>keytool -list -keystore 1.p12 -storetype pkcs12 -v
助言がありますか?
私は解決策を見つけました。主なアイデアは、証明書を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);
}
}
}
}