java.security.cert.CertificateParsingException : signed fields invalid

标签 java security encryption x509certificate digital-certificate

我正在尝试读取 X509 证书

FileInputStream fr = new FileInputStream("suresh.pfx");
CertificateFactory cf =   CertificateFactory.getInstance("X509");
X509Certificate c = (X509Certificate) cf.generateCertificate(fr); 

然后遇到异常

java.security.cert.CertificateParsingException: signed fields invalid
    at sun.security.x509.X509CertImpl.parse(Unknown Source)
    at sun.security.x509.X509CertImpl.<init>(Unknown Source)
    at sun.security.provider.X509Factory.engineGenerateCertificate(Unknown Source)
    at java.security.cert.CertificateFactory.generateCertificate(Unknown Source)
    at com.nextenders.certificategeenrator.CertificateGenerator.testGenerateSignCertWithKeyStore(CertificateGenerator.java:102)
    at com.nextenders.certificategeenrator.CertificateGenerator.main(CertificateGenerator.java:65)

Oracle forum找到了相关的东西没有解决方案。

有什么提示吗?

最佳答案

PFX 本身不是证书,而是 keystore 。

要获取证书,您必须将 pfx 加载到 keystore 中,然后获取证书:

InputStream certIs=new FileInputStream("suresh.pfx");
Keystore ks=KeyStore.getInstance("PKCS12");
ks.load(certIs.getInputStream(),"password".toCharArray());
Certificate cert=ks.getCertificate("alias");

问候

关于java.security.cert.CertificateParsingException : signed fields invalid,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21794117/

相关文章:

java - Intellij IDEA 2017.1.5 安装插件时连接超时

php - 用于 PHP 的 libsodium 无法正常工作

java - 加密类加载器

javascript - window.crypto.subtle.encrypt 用于 AES-CBC 的填充是什么

java - 生成数字证书时传递1024和2048之间的区别

java - 在继续 Android 之前等待 GPS 位置

java - 如何从邻接表创建图形图像?

java - 基于枚举测试条件

c++ - snprintf Format String 安全漏洞问题

linux - 缓冲区溢出误解