java - 需要帮助理解 getAcceptedIssuers 方法

标签 java android x509certificate

我正在编写代码以从 Android 设备获取所有受信任的证书。

这是我的代码,

public class MyX509TrustManager implements X509TrustManager {
X509TrustManager pkixTrustManager;

public MyX509TrustManager(KeyStore keystore)
        throws Exception {

    TrustManagerFactory tmf = TrustManagerFactory.getInstance("X509");
    tmf.init(keystore);

    TrustManager tms[] = tmf.getTrustManagers();

    for (int i = 0; i < tms.length; i++) {
        if (tms[i] instanceof X509TrustManager) {
            pkixTrustManager = (X509TrustManager) tms[i];

            System.out.println("The class is " + pkixTrustManager.getClass());
            return;
        }
    }

    throw new Exception("Couldn't initialize");
}

public void checkClientTrusted(X509Certificate[] arg0, String arg1)
        throws CertificateException {

    try {
        pkixTrustManager.checkClientTrusted(arg0, arg1);
    } catch (CertificateException excep) {

    }

}

public void checkServerTrusted(X509Certificate[] arg0, String arg1)
        throws CertificateException {
    // TODO Auto-generated method stub
    try {
        pkixTrustManager.checkServerTrusted(arg0, arg1);
    } catch (CertificateException excep) {

    }
}

public X509Certificate[] getAcceptedIssuers() {


    System.out.println("Control inside the issuers method");

    System.out.println( "Number of trusted certificates is "+   pkixTrustManager.getAcceptedIssuers().length);
    return pkixTrustManager.getAcceptedIssuers();

}
}

当我调用 getAcceptedIssuers 方法时,我得到空数组(由 getacceptedIssuers 方法返回的数组长度确认)

我在这里做错了什么。

任何人都可以帮我从 Android 设备获取受信任的证书列表吗?

编辑

我在另一个类中调用 MyX509TrustManager 的构造函数:

KeyStore ks = KeyStore.getInstance(KeyStore.getDefaultType());
// KeyStore.getDefaultType() returns "BKS"

MyX509TrustManager mm = new MyX509TrustManager(ks);

X509Certificate [] trucerts = m.getAcceptedIssuers();

如何加载带有受信任证书的 keystore ?

最佳答案

您在调用构造函数 MyX509TrustManager(KeyStore keystore) 时提供的 keystore 未持有任何证书颁发机构的任何证书。

例如,您可以创建一个 KeyStore 对象并用文件系统中 keystore 的内容( key 、证书、CA 证书...)填充它:

KeyStore ks = KeyStore.getInstance(KeyStore.getDefaultType());

// get user password and file input stream
char[] password = "password of the keystore in the file system";

java.io.FileInputStream fis = null;
try {
    fis = new java.io.FileInputStream("keyStoreName");
    ks.load(fis, password);
} finally {
    if (fis != null) {
        fis.close();
    }
}

关于java - 需要帮助理解 getAcceptedIssuers 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24843825/

相关文章:

java - 无法实例化类;没有空构造函数

java - 使用自签名证书生成签名

java - 在 Java 中使用证书进行编程

azure - 如何让 AzureRM 应用程序网关将 ACME .PEM 证书作为 AGW SSL 端到端配置中的 trust_root_certificates?

Java : replacing all URLs with anchor tags that aren't already in anchor tags

java - 当 XSD 驻留在 JAR 中时,如何将包含另一个 XSD 的 XSD 与 JAXB 一起使用?

java - Neo4j 4.2 graph repo 保存方法现在不明确

android - 如何以编程方式识别 Android 设备?

java - 使用 BeanItemContainer 添加表列

android - 如何从我的应用程序将电子书上传到 google play book?