如何使用工作证书验证根证书

工作证书对根证书的验证主要是验证根证书的公钥。

已知根证书的格式为pem,工作证书格式为crt,验证流程为

1、读取根证书pem文件,获取根证书公钥;

2、读取工作证书文件,获取工作证书;

3、使用工作证书验证根证书公钥,验证通过,则说明该工作证书是根证书下发的

具体代码片段如下:

/**
     * 根据根证书获取根证书公钥
     * 
     * @param rootCertPath 根证书路径
     * @return
     * @throws Exception
     */
    public static PublicKey getRootCertPublicKeyFromPem(String rootCertPath) throws Exception {
        FileInputStream fis = new FileInputStream(new File(rootCertPath));
        CertificateFactory ft = CertificateFactory.getInstance("X.509");
        X509Certificate certificate = (X509Certificate) ft.generateCertificate(fis);
        PublicKey publicKey = certificate.getPublicKey();
        return publicKey;
    }

// 从读到的工作证书临时缓存文件中获取到工作证书
 FileInputStream fis = new FileInputStream(new File(workCertTmpPath));
 CertificateFactory ft = CertificateFactory.getInstance("X.509");
  X509Certificate certificate = (X509Certificate) ft.generateCertificate(fis);

 

/**
     * 使用用户证书验证根证书的公钥,如果验证通过说明这个用户证书是这个根证书签发的,验证不过就不是这个根证书签发的。
     * 
     * @param rootCert
     * @param publicKey 根证书公钥
     * @return
     */
    public static boolean verifyRootCerUseWorkCert(X509Certificate workCert, PublicKey publicKey) {
        if (workCert == null || publicKey == null) {
            return false;
        } else {
            try {
                workCert.checkValidity(); // to check it's valid in time
                workCert.verify(publicKey); // verify the sig. using the issuer's public key
                // 走到这一步,说明验证成功
                return true;
            } catch (CertificateExpiredException e) {
                e.printStackTrace();
            } catch (CertificateNotYetValidException e) {
                e.printStackTrace();
            } catch (InvalidKeyException e) {
                e.printStackTrace();
            } catch (CertificateException e) {
                e.printStackTrace();
            } catch (NoSuchAlgorithmException e) {
                e.printStackTrace();
            } catch (NoSuchProviderException e) {
                e.printStackTrace();
            } catch (SignatureException e) {
                e.printStackTrace();
            }
            // 如果发生异常,则说明验证失败
            return false;
        }
    }

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

晒干的老咸鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值