在过去,我曾尝试使用以下代码使用PDFBox解密PDF:
if (doc.isEncrypted()){
doc.openProtection(new StandardDecryptionMaterial(password));
doc.setAllSecurityToBeRemoved(true);
}(请注意,我不使用doc.decrypt(password),因为用于解密()的Javadoc说openProtection()。
不管怎么说,这已经成功了好一段时间了。然而,最近我似乎得到了以下例外:
java.io.IOException: javax.crypto.BadPaddingException: Given final block not properly padded
at javax.crypto.CipherInputStream.getMoreData(CipherInputStream.java:118)
at javax.crypto.CipherInputStream.read(CipherInputStream.java:236)
at javax.crypto.CipherInputStream.read(CipherInputStream.java:212)
at org.apache.pdfbox.pdmodel.encryption.SecurityHandler.encryptData(SecurityHandler.java:316)
at org.apache.pdfbox.pdmodel.encryption.SecurityHandler.decryptStream(SecurityHandler.java:421)
at org.apache.pdfbox.pdmodel.encryption.SecurityHandler.decrypt(SecurityHandler.java:390)
at org.apache.pdfbox.pdmodel.encryption.SecurityHandler.decryptObject(SecurityHandler.java:365)
at org.apache.pdfbox.pdmodel.encryption.SecurityHandler.proceedDecryption(SecurityHandler.java:196)
at org.apache.pdfbox.pdmodel.encryption.StandardSecurityHandler.decryptDocument(StandardSecurityHandler.java:158)
at org.apache.pdfbox.pdmodel.PDDocument.openProtection(PDDocument.java:1598)
<Stack trace continues with my call to openProtection()>我怎样才能解决这个问题?
发布于 2014-11-17 00:24:31
这是一个已知的问题,它似乎是由于Java而引入的。在撰写本文时,将在1.8.8版本中包含对此的修复,因此只需升级到版本1.8.8或更高版本,这个问题就会消失。
https://stackoverflow.com/questions/26963718
复制相似问题