java 生成crl吊销列表_【安全】吊销列表的使用

吊销列表

吊销列表(Certificate Revocation List)列出不能再使用的证书。吊销列表文件具有两种格式:

一种是二进制格式,使用DER的编码格式,DER是BER编码规则的一个子集;文件名以.crl结尾。

另外一种是文本格式,使用的是Base64编码并且带头带尾的特定格式,Base64是用于将不可见字符转换为可见字符的一种编码;文件名以.pem结尾。

吊销列表内容

吊销列表文件包含以下内容:吊销证书的序列号,吊销日期,以及吊销列表文件自身的一些信息如类型,版本,更新日期,下次更新日期,签名算法等。我们可以下载CERTivity软件查看CRL文件内容。

打开CERTivity

ac463810899d7b100bc8df6ca046e604.png

执行快捷键“CTRL+L”选择需要打开CRL文件(CERTivity自带了示例的crl文件)

80fb9217c8f2c8b056d649827abfb90e.png

点击确定

c80d0da085153149d7e91d5ee22f49ff.png

另外一种获取吊销列表文件及打开吊销列表文件的方式:

随便打开一个https的网站,然后按照下图的方式寻找CRL分发点的URL

61b49ee12d650483d25340403d8c964b.png

复制CRL分发点的URL到新的浏览器页签下载CRL文件

双击CRL文件

CRL文件的常规信息

6189219c4a739edc56bb9c97f7c6cbc7.png

CRL文件的吊销证书序列号和吊销日期

87cf9dbc01901600ccdfb21adb06ce02.png

最后再介绍一种更方便的查看吊销列表的方式,之前刚接触crl时,不知道可以使用这种方式打开

openssl crl -noout -text -in index.crl

如何确定吊销列表吊销的是哪一张证书?

public boolean equals(Object var1) {

if (var1 == this) {

return true;

} else if (!(var1 instanceof X509CRLImpl.X509IssuerSerial)) {

return false;

} else {

X509CRLImpl.X509IssuerSerial var2 = (X509CRLImpl.X509IssuerSerial)var1;

return this.serial.equals(var2.getSerial()) && this.issuer.equals(var2.getIssuer());

}

}

如上是Java库中X509CRLImpl类中比较两个证书是否相同的代码,从代码中可以发现比较两个证书是否相同是比较了序列号和颁发者。所以我们如果需要唯一确定一张证书,需要确定它的序列号和颁发者。

如何创建证书吊销列表

吊销证书

openssl ca -revoke cert_name.crt -cert root_cert_name.crt -keyfile root_cert_name.key

吊销证书之后,记录证书的文件demoCA/index.txt中状态由V变为R,如下

V 201121083403Z 00 unknown /C=CN/ST=Beijing/O=huawei.com/CN=A

R 201121083403Z 00 unknown /C=CN/ST=Beijing/O=huawei.com/CN=A

同时,如果不吊销则无法创建Common name相同的证书。

创建吊销列表

openssl ca -gencrl -out index.crl -cert root_cert_name.crt -keyfile root_cert_name.key

root_cert_name.crt和root_cert_name.key是上级证书和上级证书的私钥

创建吊销列表之前需要先吊销证书,如果不吊销证书,那在生成吊销列表时将不会包含需要吊销的证书

Java代码读取CRL文件

public static void main(String[] args) {

try {

CertificateFactory certificateFactory = CertificateFactory.getInstance("X.509");

InputStream fileInputStream = new FileInputStream(new File("xxx.crl"));

X509CRL x509CRL = (X509CRL) certificateFactory.generateCRL(fileInputStream);

} catch (Exception e) {

e.printStackTrace();

}

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值