|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectorg.apache.poi.poifs.crypt.Decryptor
org.apache.poi.poifs.crypt.agile.AgileDecryptor
public class AgileDecryptor
Decryptor implementation for Agile Encryption
Field Summary |
---|
Fields inherited from class org.apache.poi.poifs.crypt.Decryptor |
---|
DEFAULT_PASSWORD, DEFAULT_POIFS_ENTRY, encryptionInfo |
Constructor Summary | |
---|---|
protected |
AgileDecryptor()
|
Method Summary | |
---|---|
AgileDecryptor |
clone()
|
java.io.InputStream |
getDataStream(DirectoryNode dir)
Return a stream with decrypted data. |
long |
getLength()
Returns the length of the encrypted data that can be safely read with Decryptor.getDataStream(org.apache.poi.poifs.filesystem.DirectoryNode) . |
protected static int |
getNextBlockSize(int inputLen,
int blockSize)
|
protected static javax.crypto.Cipher |
initCipherForBlock(javax.crypto.Cipher existing,
int block,
boolean lastChunk,
EncryptionInfo encryptionInfo,
javax.crypto.SecretKey skey,
int encryptionMode)
|
boolean |
verifyPassword(java.security.KeyPair keyPair,
java.security.cert.X509Certificate x509)
instead of a password, it's also possible to decrypt via certificate. |
boolean |
verifyPassword(java.lang.String password)
set decryption password |
Methods inherited from class org.apache.poi.poifs.crypt.Decryptor |
---|
getBlockSizeInBytes, getDataStream, getDataStream, getDataStream, getDataStream, getEncryptionInfo, getInstance, getIntegrityHmacKey, getIntegrityHmacValue, getKeySizeInBytes, getSecretKey, getVerifier, initCipherForBlock, setChunkSize, setEncryptionInfo, setIntegrityHmacKey, setIntegrityHmacValue, setSecretKey, setVerifier |
Methods inherited from class java.lang.Object |
---|
equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
protected AgileDecryptor()
Method Detail |
---|
public boolean verifyPassword(java.lang.String password) throws java.security.GeneralSecurityException
verifyPassword
in class Decryptor
java.security.GeneralSecurityException
public boolean verifyPassword(java.security.KeyPair keyPair, java.security.cert.X509Certificate x509) throws java.security.GeneralSecurityException
keyPair
- x509
-
java.security.GeneralSecurityException
protected static int getNextBlockSize(int inputLen, int blockSize)
public java.io.InputStream getDataStream(DirectoryNode dir) throws java.io.IOException, java.security.GeneralSecurityException
Decryptor
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
getDataStream
in class Decryptor
dir
- the node to read from
java.io.IOException
java.security.GeneralSecurityException
public long getLength()
Decryptor
Decryptor.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 discarded
The 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.
getLength
in class Decryptor
protected static javax.crypto.Cipher initCipherForBlock(javax.crypto.Cipher existing, int block, boolean lastChunk, EncryptionInfo encryptionInfo, javax.crypto.SecretKey skey, int encryptionMode) throws java.security.GeneralSecurityException
java.security.GeneralSecurityException
public AgileDecryptor clone() throws java.lang.CloneNotSupportedException
clone
in class Decryptor
java.lang.CloneNotSupportedException
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |