java.security.cert.CertificateParsingException:签名字段无效

Sur*_*tta 4 java security encryption digital-certificate x509certificate

我正在尝试阅读 X509 certificate

FileInputStream fr = new FileInputStream("suresh.pfx");
CertificateFactory cf =   CertificateFactory.getInstance("X509");
X509Certificate c = (X509Certificate) cf.generateCertificate(fr); 
Run Code Online (Sandbox Code Playgroud)

并运行到例外

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)
Run Code Online (Sandbox Code Playgroud)

Oracle论坛找到与之相关的东西,没有解决方案.

任何提示?

小智 8

PFX本身不是证书,而是密钥库.

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

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

问候