栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

在Java中验证PKCS#7证书

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

在Java中验证PKCS#7证书

自己找到解决方案。因此,这是如何针对受信任的存储提取和验证证书链的方法(为便于阅读,跳过了异常处理):

CertificateFactory cf = CertificateFactory.getInstance("X.509");// Get ContentInfo//byte[] signature = ... // PKCS#7 signature bytesInputStream signatureIn = new ByteArrayInputStream(signature);DERObject obj = new ASN1InputStream(signatureIn).readObject();ContentInfo contentInfo = ContentInfo.getInstance(obj);// Extract certificatesSignedData signedData = SignedData.getInstance(contentInfo.getContent());Enumeration certificates = signedData.getCertificates().getObjects();// Build certificate pathList certList = new ArrayList();while (certificates.hasMoreElements()) {    DERObject certObj = (DERObject) certificates.nextElement();    InputStream in = new ByteArrayInputStream(certObj.getDEREnpred());    certList.add(cf.generateCertificate(in));}CertPath certPath = cf.generateCertPath(certList);// Load key store//String keyStorePath = ...KeyStore keyStore = KeyStore.getInstance("JKS");keyStore.load(new FileInputStream(keyStorePath), null);// Set validation parametersPKIXParameters params = new PKIXParameters(keyStore);params.setRevocationEnabled(false); // to avoid exception on empty CRL// Validate certificate pathCertPathValidator validator = CertPathValidator.getInstance("PKIX");CertPathValidatorResult result = validator.validate(certPath, params);

validate()
如果验证失败,将抛出异常。

文档:

ASN1Set
ContentInfo
SignedData
。其他所有外来名称和相关文档都可以在中找到
java.security.cert

这里没有SUN依赖项,仅需要BouncyCastle提供程序库。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/508508.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号