public class AESNativeCTR extends java.lang.Object implements StreamCipher, SkippingStreamCipher, MultiBlockCipher
| Constructor and Description |
|---|
AESNativeCTR() |
| Modifier and Type | Method and Description |
|---|---|
java.lang.String |
getAlgorithmName()
Return the name of the algorithm the cipher implements.
|
int |
getBlockSize()
Return the block size for this cipher (in bytes).
|
int |
getMultiBlockSize()
Return the multi-block size for this cipher (in bytes).
|
long |
getPosition()
Return the current "position" of the cipher
|
void |
init(boolean forEncryption,
CipherParameters params)
Initialise the cipher.
|
int |
processBlock(byte[] in,
int inOff,
byte[] out,
int outOff)
Process one block of input from the array in and write it to
the out array.
|
int |
processBlocks(byte[] in,
int inOff,
int blockCount,
byte[] out,
int outOff)
Process blockCount blocks from input in offset inOff and place the output in
out from offset outOff.
|
int |
processBytes(byte[] in,
int inOff,
int len,
byte[] out,
int outOff)
process a block of bytes from in putting the result into out.
|
void |
reset()
reset the cipher.
|
byte |
returnByte(byte in)
encrypt/decrypt a single byte returning the result.
|
long |
seekTo(long position)
Reset the cipher and then skip forward to a given position.
|
long |
skip(long numberOfBytes)
Skip numberOfBytes forwards, or backwards.
|
java.lang.String |
toString() |
public int getBlockSize()
BlockCiphergetBlockSize in interface BlockCipherpublic int processBlock(byte[] in,
int inOff,
byte[] out,
int outOff)
throws DataLengthException,
java.lang.IllegalStateException
BlockCipherprocessBlock in interface BlockCipherin - the array containing the input data.inOff - offset into the in array the data starts at.out - the array the output data will be copied into.outOff - the offset into the out array the output will start at.DataLengthException - if there isn't enough data in input , or
space in out.java.lang.IllegalStateException - if the cipher isn't initialised.public int getMultiBlockSize()
MultiBlockCiphergetMultiBlockSize in interface MultiBlockCipherpublic int processBlocks(byte[] in,
int inOff,
int blockCount,
byte[] out,
int outOff)
throws DataLengthException,
java.lang.IllegalStateException
MultiBlockCipherprocessBlocks in interface MultiBlockCipherin - input data array.inOff - start of input data in in.blockCount - number of blocks to be processed.out - output data array.outOff - start position for output data.DataLengthExceptionjava.lang.IllegalStateExceptionpublic long skip(long numberOfBytes)
SkippingCipherskip in interface SkippingCiphernumberOfBytes - the number of bytes to skip (positive forward, negative backwards).public long seekTo(long position)
SkippingCipherseekTo in interface SkippingCipherposition - the number of bytes in to set the cipher state to.public long getPosition()
SkippingCiphergetPosition in interface SkippingCipherpublic void init(boolean forEncryption,
CipherParameters params)
throws java.lang.IllegalArgumentException
StreamCipherinit in interface BlockCipherinit in interface StreamCipherforEncryption - if true the cipher is initialised for
encryption, if false for decryption.params - the key and other data required by the cipher.java.lang.IllegalArgumentException - if the params argument is
inappropriate.public java.lang.String getAlgorithmName()
StreamCiphergetAlgorithmName in interface BlockCiphergetAlgorithmName in interface StreamCipherpublic byte returnByte(byte in)
StreamCipherreturnByte in interface StreamCipherin - the byte to be processed.public int processBytes(byte[] in,
int inOff,
int len,
byte[] out,
int outOff)
throws DataLengthException
StreamCipherprocessBytes in interface StreamCipherin - the input byte array.inOff - the offset into the in array where the data to be processed starts.len - the number of bytes to be processed.out - the output buffer the processed bytes go into.outOff - the offset into the output byte array the processed data starts at.DataLengthException - if the output buffer is too small.public void reset()
StreamCipherreset in interface BlockCipherreset in interface StreamCipherpublic java.lang.String toString()
toString in class java.lang.Object