Class BinaryRC4Decryptor
- java.lang.Object
-
- org.apache.poi.poifs.crypt.Decryptor
-
- org.apache.poi.poifs.crypt.binaryrc4.BinaryRC4Decryptor
-
- All Implemented Interfaces:
java.lang.Cloneable
public class BinaryRC4Decryptor extends Decryptor implements java.lang.Cloneable
-
-
Field Summary
-
Fields inherited from class org.apache.poi.poifs.crypt.Decryptor
DEFAULT_PASSWORD, DEFAULT_POIFS_ENTRY
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description BinaryRC4Decryptorclone()java.io.InputStreamgetDataStream(java.io.InputStream stream, int size, int initialPos)Wraps a stream for decryptionChunkedCipherInputStreamgetDataStream(DirectoryNode dir)Return a stream with decrypted data.longgetLength()Returns the length of the encrypted data that can be safely read withDecryptor.getDataStream(org.apache.poi.poifs.filesystem.DirectoryNode).javax.crypto.CipherinitCipherForBlock(javax.crypto.Cipher cipher, int block)Initializes a cipher object for a given block index for encryptionvoidsetChunkSize(int chunkSize)Sets the chunk size of the data stream.booleanverifyPassword(java.lang.String password)-
Methods inherited from class org.apache.poi.poifs.crypt.Decryptor
getDataStream, getEncryptionInfo, getInstance, getIntegrityHmacKey, getIntegrityHmacValue, getSecretKey, getVerifier, setEncryptionInfo
-
-
-
-
Method Detail
-
verifyPassword
public boolean verifyPassword(java.lang.String password)
- Specified by:
verifyPasswordin classDecryptor
-
initCipherForBlock
public javax.crypto.Cipher initCipherForBlock(javax.crypto.Cipher cipher, int block) throws java.security.GeneralSecurityExceptionDescription copied from class:DecryptorInitializes a cipher object for a given block index for encryption- Overrides:
initCipherForBlockin classDecryptor- Parameters:
cipher- may be null, otherwise the given instance is reset to the new block indexblock- the block index, e.g. the persist/slide id (hslf)- Returns:
- a new cipher object, if cipher was null, otherwise the reinitialized cipher
- Throws:
java.security.GeneralSecurityException- if the cipher can't be initialized
-
getDataStream
public ChunkedCipherInputStream getDataStream(DirectoryNode dir) throws java.io.IOException, java.security.GeneralSecurityException
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:
java.io.IOExceptionjava.security.GeneralSecurityException
-
getDataStream
public java.io.InputStream getDataStream(java.io.InputStream stream, int size, int initialPos) throws java.io.IOException, java.security.GeneralSecurityExceptionDescription copied from class:DecryptorWraps a stream for decryptionAs we are handling streams and don't know the total length beforehand, it's the callers duty to care for the length of the entries.
- Overrides:
getDataStreamin classDecryptor- Parameters:
stream- the stream to be wrappedinitialPos- initial/current byte position within the stream- Returns:
- decrypted stream
- Throws:
java.io.IOExceptionjava.security.GeneralSecurityException
-
getLength
public long getLength()
Description copied from class:DecryptorReturns the length of the encrypted data that can be safely read withDecryptor.getDataStream(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.apache.poi.poifs.filesystem.DirectoryNode), an attempt to call getLength() prior to getDataStream() will result in IllegalStateException.
-
setChunkSize
public void setChunkSize(int chunkSize)
Description copied from class:DecryptorSets the chunk size of the data stream. Needs to be set before the data stream is requested. When not set, the implementation uses method specific default values- Overrides:
setChunkSizein classDecryptor- Parameters:
chunkSize- the chunk size, i.e. the block size with the same encryption key
-
clone
public BinaryRC4Decryptor clone() throws java.lang.CloneNotSupportedException
-
-