Class PDFDecrypterFactory
java.lang.Object
com.sun.pdfview.decrypt.PDFDecrypterFactory
Produces a
PDFDecrypter for documents given a (possibly non-existent)
Encrypt dictionary. Supports decryption of versions 1, 2 and 4 of the
password-based encryption mechanisms as described in PDF Reference version
1.7. This means that it supports RC4 and AES encryption with keys of
40-128 bits; esentially, password-protected documents with compatibility
up to Acrobat 8.- Author:
- Luke Kirby
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final StringThe name of the standard Identity CryptFilter -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionstatic PDFDecryptercreateDecryptor(PDFObject encryptDict, PDFObject documentId, PDFPassword password) Create a decryptor for a given encryption dictionary.
-
Field Details
-
CF_IDENTITY
-
-
Constructor Details
-
PDFDecrypterFactory
public PDFDecrypterFactory()
-
-
Method Details
-
createDecryptor
public static PDFDecrypter createDecryptor(PDFObject encryptDict, PDFObject documentId, PDFPassword password) throws IOException, EncryptionUnsupportedByPlatformException, EncryptionUnsupportedByProductException, PDFAuthenticationFailureException Create a decryptor for a given encryption dictionary. A check is immediately performed that the supplied password decrypts content described by the encryption specification.- Parameters:
encryptDict- the Encrypt dict as found in the document's trailer. May be null, in which case theIdentityDecrypterwill be returned.documentId- the object with key "ID" in the trailer's dictionary. Should always be present if Encrypt is.password- the password to use; may benull- Returns:
- The decryptor that should be used for all encrypted data in the PDF
- Throws:
IOException- will typically be aPDFParseException, indicating an IO problem, an error in the structure of the document, or a failure to obtain various ciphers from the installed JCE providersEncryptionUnsupportedByPlatformException- if the encryption is not supported by the environment in which the code is executingEncryptionUnsupportedByProductException- if PDFRenderer does not currently support the specified encryptionPDFAuthenticationFailureException- if the supplied password was not able to
-