检查 Java 密钥库中的证书到期日期

2022-09-01 20:46:32

我的java应用程序使用一个密钥库文件,其中我有一个证书,该证书用于与活动目录服务器的ssl连接。我所要做的是检查其到期日期并提示用户其关闭是否过期。我必须在应用程序启动时执行此操作。我的想法是使用外部程序:keytool来显示有关密钥库中某些证书的信息,然后对keytool输出的字符串执行一些解析操作以查找此验证日期。

下面是特定 keytool 命令的输出:

Owner:
Issuer: CN=CPD Root CA, DC=cpd, DC=local<br>
Serial number: 39e8d1610002000000cb
<br>Valid from: Wed Feb 22 21:36:31 CET 2012 until: Thu Feb 21 21:36:31 CET 2013
Certificate fingerprints: <br>
         MD5:  82:46:8B:DB:BC:5C:64:21:84:BB:68:E3:4B:D4:35:70<br>
         SHA1: 35:52:CA:F2:11:66:1E:50:63:BC:53:A5:50:C1:F0:1E:62:81:BC:3F<br>
         Signature algorithm name: SHA1withRSA

问题在于解析日期,因为我无法确定它以哪种格式显示。

有没有更简单的方法来检查java密钥库文件中包含的证书的到期日期?


答案 1

感谢您的EJP方向,这是我想到的一块。

    try {
        KeyStore keystore = KeyStore.getInstance(KeyStore.getDefaultType());
        keystore.load(new FileInputStream("keystoreLocation"), "keystorePassword".toCharArray());
        Enumeration<String> aliases = keystore.aliases();
        while(aliases.hasMoreElements()){
            String alias = aliases.nextElement();
            if(keystore.getCertificate(alias).getType().equals("X.509")){
                System.out.println(alias + " expires " + ((X509Certificate) keystore.getCertificate(alias)).getNotAfter());
            }
        }
    } catch (Exception e) {
        e.printStackTrace();
    }

答案 2

使用该类装入密钥库并枚举其内容,并检查每个证书的过期时间。java.security.Keystore