Вопрос по java, certificate, saml – Чтение сертификата X.509 с Java
Я пытаюсь использовать Java для чтения сертификата, полученного от внешней стороны. Код выбрасывает следующую ошибку:
java.lang.RuntimeException: java.security.cert.CertificateException: Unable to initialize, java.io.IOException: extra data given to DerValue constructor
Код:
FileInputStream ksfis = new FileInputStream(this.getCertificateFile());
ksbufin = new BufferedInputStream(ksfis);
certificate = (X509Certificate)
CertificateFactory.getInstance("X.509").generateCertificate(ksbufin);
Чтобы убедиться, что проблема не в коде, я создал самозаверяющий сертификат и использовал его с кодом, и он работал нормально. Я установил оба сертификата в системной цепочке ключей, и они оба действительны. Я использую Mac и Java 1.6.
Любая идея, почему я получаю вышеуказанное исключение при загрузке сертификата внешней стороны? Как вы думаете, он был поврежден во время передачи? Если это так, он не должен отображаться как действительный в локальной системе, верно?
----- START CERTIFICATE ----- \n base 64 junk \n ----- END CERTIFICATE -----
Я предполагаю?
Maarten Bodewes
Попробуйте напечатать это с помощью openssl, а затем импортируйте результат:
openssl x509 -outform der -in certificate.pem -out certificate.der
или используйте функциональность Java Bouncy Castle в облегченном API:
http://www.bouncycastle.org/docs/pkixdocs1.5on/org/bouncycastle/openssl/PEMReader.html
Вы можете снова закодировать результат и затем использовать сертификат по умолчанию CertificateBuilder в Java, чтобы получить определенный сертификат JCE.