Class CryptoAPIDecryptor
- java.lang.Object
- 
- org.apache.poi.poifs.crypt.Decryptor
- 
- org.apache.poi.poifs.crypt.cryptoapi.CryptoAPIDecryptor
 
 
- 
- All Implemented Interfaces:
- GenericRecord
 
 public class CryptoAPIDecryptor extends Decryptor 
- 
- 
Field Summary- 
Fields inherited from class org.apache.poi.poifs.crypt.DecryptorDEFAULT_PASSWORD, DEFAULT_POIFS_ENTRY, encryptionInfo
 
- 
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedCryptoAPIDecryptor()protectedCryptoAPIDecryptor(CryptoAPIDecryptor other)
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description CryptoAPIDecryptorcopy()protected static SecretKeygenerateSecretKey(String password, EncryptionVerifier ver)ChunkedCipherInputStreamgetDataStream(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).POIFSFileSystemgetSummaryEntries(DirectoryNode root, String encryptedStream)Decrypt the Document-/SummaryInformation and other optionally streams.CipherinitCipherForBlock(Cipher cipher, int block)Initializes a cipher object for a given block index for encryptionprotected static CipherinitCipherForBlock(Cipher cipher, int block, EncryptionInfo encryptionInfo, SecretKey skey, int encryptMode)voidsetChunkSize(int chunkSize)Sets the chunk size of the data stream.booleanverifyPassword(String password)- 
Methods inherited from class org.apache.poi.poifs.crypt.DecryptorgetBlockSizeInBytes, getDataStream, getEncryptionInfo, getGenericProperties, getInstance, getIntegrityHmacKey, getIntegrityHmacValue, getKeySizeInBytes, getSecretKey, getVerifier, setEncryptionInfo, setIntegrityHmacKey, setIntegrityHmacValue, setSecretKey, setVerifier
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.apache.poi.common.usermodel.GenericRecordgetGenericChildren, getGenericRecordType
 
- 
 
- 
- 
- 
Constructor Detail- 
CryptoAPIDecryptorprotected CryptoAPIDecryptor() 
 - 
CryptoAPIDecryptorprotected CryptoAPIDecryptor(CryptoAPIDecryptor other) 
 
- 
 - 
Method Detail- 
verifyPasswordpublic boolean verifyPassword(String password) - Specified by:
- verifyPasswordin class- Decryptor
 
 - 
initCipherForBlockpublic Cipher initCipherForBlock(Cipher cipher, int block) throws GeneralSecurityException Description copied from class:DecryptorInitializes a cipher object for a given block index for encryption- Overrides:
- initCipherForBlockin class- Decryptor
- Parameters:
- cipher- may be null, otherwise the given instance is reset to the new block index
- block- the block index, e.g. the persist/slide id (hslf)
- Returns:
- a new cipher object, if cipher was null, otherwise the reinitialized cipher
- Throws:
- GeneralSecurityException- if the cipher can't be initialized
 
 - 
initCipherForBlockprotected static Cipher initCipherForBlock(Cipher cipher, int block, EncryptionInfo encryptionInfo, SecretKey skey, int encryptMode) throws GeneralSecurityException - Throws:
- GeneralSecurityException
 
 - 
generateSecretKeyprotected static SecretKey generateSecretKey(String password, EncryptionVerifier ver) 
 - 
getDataStreampublic ChunkedCipherInputStream getDataStream(DirectoryNode dir) throws IOException, 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 class- Decryptor
- Parameters:
- dir- the node to read from
- Returns:
- decrypted stream
- Throws:
- IOException
- GeneralSecurityException
 
 - 
getDataStreampublic ChunkedCipherInputStream getDataStream(InputStream stream, int size, int initialPos) throws IOException, GeneralSecurityException Description 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 class- Decryptor
- Parameters:
- stream- the stream to be wrapped
- initialPos- initial/current byte position within the stream
- Returns:
- decrypted stream
- Throws:
- IOException
- GeneralSecurityException
 
 - 
getSummaryEntriespublic POIFSFileSystem getSummaryEntries(DirectoryNode root, String encryptedStream) throws IOException, GeneralSecurityException Decrypt the Document-/SummaryInformation and other optionally streams. Opposed to other crypto modes, cryptoapi is record based and can't be used to stream-decrypt a whole file.Summary entries are only encrypted within cryptoapi encrypted files. Binary RC4 encrypted files use non-encrypted/default property sets - Parameters:
- root- root directory node of the OLE file containing the encrypted properties
- encryptedStream- name of the encrypted stream - "encryption" for HSSF/HWPF, "encryptedStream" (or encryptedSummary?) for HSLF
- Throws:
- IOException
- GeneralSecurityException
- See Also:
- 2.3.5.4 RC4 CryptoAPI Encrypted Summary Stream
 
 - 
getLengthpublic 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.- Specified by:
- getLengthin class- Decryptor
- Returns:
- the length of the stream returned by getDataStream(DirectoryNode)
 
 - 
setChunkSizepublic 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 class- Decryptor
- Parameters:
- chunkSize- the chunk size, i.e. the block size with the same encryption key
 
 - 
copypublic CryptoAPIDecryptor copy() 
 
- 
 
-