使用SSL证书签名PDF文件

时间:2013-04-16 05:12:30

标签: java itext keystore digital-certificate

我的应用程序有SSL证书,我想用它来使用iText对PDF文件进行数字签名。证书的扩展名为.cer,由证书签名机构(CA)提供。

问题是我无法将此.cer证书转换为使用itext库签名PDF时所需的java密钥库。我的代码是:

此代码显然会抛出无效的密钥库格式IOException。

KeyStore ks = KeyStore.getInstance(KeyStore.getDefaultType());
ks.load(new FileInputStream("C:\\abc.cer"), "abcd".toCharArray());
String alias = (String) ks.aliases().nextElement();
PrivateKey key = (PrivateKey) ks.getKey(alias, "abcd".toCharArray());
java.security.cert.Certificate[] chain = ks.getCertificateChain(alias);
PdfReader reader = new PdfReader("C:\\test.pdf");
FileOutputStream fout = new FileOutputStream("C:\\signed.pdf");
PdfStamper stp = PdfStamper.createSignature(reader, fout, '\0');
PdfSignatureAppearance sap = stp.getSignatureAppearance();
sap.setCrypto(key, chain, null, PdfSignatureAppearance.WINCER_SIGNED);
sap.setReason("Test Reason");
sap.setLocation("Test Location");
sap.setVisibleSignature(new Rectangle(10, 10, 20, 20), 1, null);
stp.close();

请告诉我如何将SSL证书转换为java密钥库并将其用于签署pdf文件。

1 个答案:

答案 0 :(得分:5)

首先,证书不是“SSL证书”。它们是x.509证书,其中一些可用于SSL / TLS身份验证。如果您拥有此类证书,则不能将其用于其他目的,包括PDF签名。

接下来,.cer文件是证书的公共部分,它不包含私钥。您需要证书私钥才能签署任何内容。