Class AgileDecryptor
java.lang.Object
org.docx4j.org.apache.poi.poifs.crypt.Decryptor
org.docx4j.org.apache.poi.poifs.crypt.agile.AgileDecryptor
Decryptor implementation for Agile Encryption
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprivate class2.3.4.15 Data Encryption (Agile Encryption) The EncryptedPackage stream (1) MUST be encrypted in 4096-byte segments to facilitate nearly random access while allowing CBC modes to be used in the encryption process. -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate longprotected static final byte[]protected static final byte[]protected static final byte[]protected static final byte[]protected static final byte[]Fields inherited from class org.docx4j.org.apache.poi.poifs.crypt.Decryptor
builder, DEFAULT_PASSWORD, DEFAULT_POIFS_ENTRY -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionReturn a stream with decrypted data.longReturns the length of the encrypted data that can be safely read withDecryptor.getDataStream(org.docx4j.org.apache.poi.poifs.filesystem.DirectoryNode).protected static intgetNextBlockSize(int inputLen, int blockSize) protected static byte[]hashInput(EncryptionInfoBuilder builder, byte[] pwHash, byte[] blockKey, byte[] inputKey, int cipherMode) protected static CipherinitCipherForBlock(Cipher existing, int block, boolean lastChunk, EncryptionInfoBuilder builder, SecretKey skey, int encryptionMode) booleanverifyPassword(String password) set decryption passwordbooleanverifyPassword(KeyPair keyPair, X509Certificate x509) instead of a password, it's also possible to decrypt via certificate.Methods inherited from class org.docx4j.org.apache.poi.poifs.crypt.Decryptor
getBlockSizeInBytes, getDataStream, getDataStream, getDataStream, getInstance, getIntegrityHmacKey, getIntegrityHmacValue, getKeySizeInBytes, getSecretKey, getVerifier, setIntegrityHmacKey, setIntegrityHmacValue, setSecretKey, setVerifier
-
Field Details
-
_length
private long _length -
kVerifierInputBlock
protected static final byte[] kVerifierInputBlock -
kHashedVerifierBlock
protected static final byte[] kHashedVerifierBlock -
kCryptoKeyBlock
protected static final byte[] kCryptoKeyBlock -
kIntegrityKeyBlock
protected static final byte[] kIntegrityKeyBlock -
kIntegrityValueBlock
protected static final byte[] kIntegrityValueBlock
-
-
Constructor Details
-
AgileDecryptor
-
-
Method Details
-
verifyPassword
set decryption password- Specified by:
verifyPasswordin classDecryptor- Throws:
GeneralSecurityException
-
verifyPassword
public boolean verifyPassword(KeyPair keyPair, X509Certificate x509) throws GeneralSecurityException instead of a password, it's also possible to decrypt via certificate. Warning: this code is experimental and hasn't been validated- Parameters:
keyPair-x509-- Returns:
- true, when the data can be successfully decrypted with the given private key
- Throws:
GeneralSecurityException- See Also:
-
getNextBlockSize
protected static int getNextBlockSize(int inputLen, int blockSize) -
hashInput
protected static byte[] hashInput(EncryptionInfoBuilder builder, byte[] pwHash, byte[] blockKey, byte[] inputKey, int cipherMode) -
getDataStream
Description copied from class:DecryptorReturn a stream with decrypted data.Use
Decryptor.getLength()to get the size of that data that can be safely read from the stream. Just reading to the end of the input stream is not sufficient because there are normally padding bytes that must be discarded- Specified by:
getDataStreamin classDecryptor- Parameters:
dir- the node to read from- Returns:
- decrypted stream
- Throws:
IOExceptionGeneralSecurityException
-
getLength
public long getLength()Description copied from class:DecryptorReturns the length of the encrypted data that can be safely read withDecryptor.getDataStream(org.docx4j.org.apache.poi.poifs.filesystem.DirectoryNode). Just reading to the end of the input stream is not sufficient because there are normally padding bytes that must be discardedThe length variable is initialized in
Decryptor.getDataStream(org.docx4j.org.apache.poi.poifs.filesystem.DirectoryNode), an attempt to call getLength() prior to getDataStream() will result in IllegalStateException. -
initCipherForBlock
protected static Cipher initCipherForBlock(Cipher existing, int block, boolean lastChunk, EncryptionInfoBuilder builder, SecretKey skey, int encryptionMode) throws GeneralSecurityException - Throws:
GeneralSecurityException
-