我的java程序应该使用自己的密钥签署收到的X509证书请求。 证书请求采用PEM格式。签名的密钥/证书位于本地java密钥库中。
我已经从java.security
包中寻找合适的课程。但没有成功。
应该使用哪些Java API类来签署X509证书?
我可以将PEM转换为DER,但DER的解码会导致问题。 我尝试过以下方法:
BufferedInputStream bis = new BufferedInputStream(new ByteArrayInputStream(derReq));
CertificateFactory certFact = CertificateFactory.getInstance("X.509");
java.security.cert.Certificate cert = certFact.generateCertificate(bis);
和
javax.security.cert.X509Certificate cer = X509Certificate.getInstance(derReq);
两者都会导致以下异常:
javax.security.cert.CertificateException: Could not parse certificate: java.io.IOException: Empty input
因此,似乎这些仅适用于签名证书,而不适用于X509证书请求。