PDFBox +充气城堡 - 签署PDF

时间:2011-06-01 07:46:37

标签: java pdf bouncycastle sign pdfbox

我正在尝试使用PdfBox(和BouncyCastle)对PDF进行数字签名(加密?)

我创建了密钥库和证书:

%java_home%\bin\keytool -genkey -alias razor -keypass testkeypass -storepass teststorepass  -keystore test-keystore.jks -validity 360 -dname "CN=razor, OU=myorg, O=my.org, L=Mycity, C=PL"
%java_home%\bin\keytool -export -alias razor -keypass testkeypass -storepass teststorepass  -keystore test-keystore.jks -file test-cert.cer  

现在我正在尝试使用PdfBox

org.apache.pdfbox.PDFBox Encrypt -certFile test-cert.cer -canModify false -canPrint false test.pdf test-signed-out.pdf

我得到了:

Encrypt failed with the following exception:
org.apache.pdfbox.exceptions.COSVisitorException: Cannot find any provider supporting 1.2.840.10040.4.1
    at org.apache.pdfbox.pdfwriter.COSWriter.write(COSWriter.java:1025)
    at org.apache.pdfbox.pdmodel.PDDocument.save(PDDocument.java:914)
    at org.apache.pdfbox.pdmodel.PDDocument.save(PDDocument.java:895)
    at org.apache.pdfbox.Encrypt.encrypt(Encrypt.java:189)
    at org.apache.pdfbox.Encrypt.main(Encrypt.java:53)
    at org.apache.pdfbox.PDFBox.main(PDFBox.java:40)
org.apache.pdfbox.exceptions.CryptographyException: Cannot find any provider supporting 1.2.840.10040.4.1
    at org.apache.pdfbox.pdmodel.encryption.PublicKeySecurityHandler.prepareDocumentForEncryption(PublicKeySecurityHandler.java:344)
    at org.apache.pdfbox.pdfwriter.COSWriter.write(COSWriter.java:1016)

问题是什么?我做错了什么?

我可以使用已经签名的PDFBox ShowCertificate(通过iText)PDF: 签名算法:SHA1withDSA,OID = 1.2.840.10040.4.3

2 个答案:

答案 0 :(得分:1)

我不熟悉PDFBox,但我认为您的问题是“加密”命令行工具不进行签名。您似乎已创建DSA证书/密钥。 DSA用于数字签名。该例外反映了DSA不是一种有效的加密算法。

我看到了一些使用PDFBox签名的参考资料,但我认为不是这样的。

答案 1 :(得分:-1)

您需要添加提供商。

您可以使用单行代码执行此操作。

Security.addProvider(new BouncyCastleProvider());

安全性 - 来自java.security.Security

显然你需要先导入BouncyCastleProviderStuff。


哎呀 - 我刚注意到你是从命令行用一些PDFBox工具做的。 不知道如何在那里添加提供商。

相关问题