public abstract class Checksum extends Object
Checksum class is the base class for CRC (cyclic
redundancy check) checksum algorithms. Implementations of Checksum algorithms
must extend this class and implement all the abstract methods.
A tear or card reset event resets a Checksum object to the
initial state (state upon construction).
Even if a transaction is in progress, update of intermediate result state in the implementation instance shall not participate in the transaction.
| Modifier and Type | Field and Description |
|---|---|
static byte |
ALG_ISO3309_CRC16
ISO/IEC 3309 compliant 16 bit CRC algorithm.
|
static byte |
ALG_ISO3309_CRC32
ISO/IEC 3309 compliant 32 bit CRC algorithm.
|
| Modifier | Constructor and Description |
|---|---|
protected |
Checksum()
Protected Constructor
|
| Modifier and Type | Method and Description |
|---|---|
abstract short |
doFinal(byte[] inBuff,
short inOffset,
short inLength,
byte[] outBuff,
short outOffset)
Generates a CRC checksum of all/last input data.
|
abstract byte |
getAlgorithm()
Gets the Checksum algorithm.
|
static Checksum |
getInstance(byte algorithm,
boolean externalAccess)
Creates a
Checksum object instance of the selected
algorithm. |
abstract void |
init(byte[] bArray,
short bOff,
short bLen)
Resets and initializes the
Checksum object with the
algorithm specific parameters. |
abstract void |
update(byte[] inBuff,
short inOffset,
short inLength)
Accumulates a partial checksum of the input data.
|
public static final byte ALG_ISO3309_CRC16
x^16+x^12+x^5+1. The default
initial checksum value used by this algorithm is 0. This algorithm is
also compliant with the frame checking sequence as specified in section
4.2.5.2 of the ISO/IEC 13239 specification.
To obtain the commonly used CCITT behavior:
0xFFFF via the init()
method
0x1021
OxFFFF. This is the
CRC16 result.
public static final byte ALG_ISO3309_CRC32
X^32 +X^26 +X^23 +X^22 +X^16 +X^12 +X^11 +X^10 +X^8 +X^7 +X^5 +X^4 +X^2 +X +1.
The default initial checksum value used by this algorithm is 0. This
algorithm is also compliant with the frame checking sequence as specified
in section 4.2.5.3 of the ISO/IEC 13239 specification.
To obtain the PKZIP (also JDKTM java.util.zip.CRC32 class) behavior:
0xFFFFFFFF via the
init() method
0x04C11DB7
public static final Checksum getInstance(byte algorithm, boolean externalAccess) throws CryptoException
Checksum object instance of the selected
algorithm.algorithm - the desired checksum algorithm. Valid codes listed in
ALG_* constants above, for example,
ALG_ISO3309_CRC16.externalAccess - true indicates that the instance will be shared
among multiple applet instances and that the
Checksum instance will also be accessed (via a
Shareable. interface) when the owner of the
Checksum instance is not the currently selected
applet. If true the implementation must not
allocate CLEAR_ON_DESELECT transient space for internal data.Checksum object instance of the requested
algorithm.CryptoException - with the following reason codes:
CryptoException.NO_SUCH_ALGORITHM if
the requested algorithm or shared access mode is not
supported.
public abstract void init(byte[] bArray,
short bOff,
short bLen)
throws CryptoException
Checksum object with the
algorithm specific parameters.
Note:
bArray representing the initial checksum value.
bArray representing the initial checksum value.
bArray - byte array containing algorithm specific initialization
informationbOff - offset within bArray where the algorithm
specific data beginsbLen - byte length of algorithm specific parameter dataCryptoException - with the following reason codes:
CryptoException.ILLEGAL_VALUE if a
byte array parameter option is not supported by the
algorithm or if the bLen is an incorrect
byte length for the algorithm specific data.
public abstract byte getAlgorithm()
ALG_*
constants above, for example,
ALG_ISO3309_CRC16.public abstract short doFinal(byte[] inBuff,
short inOffset,
short inLength,
byte[] outBuff,
short outOffset)
inOffset and
continuing on until the byte at (inOffset+inLength-1) of
the inBuff array. Within each byte the processing proceeds
from the least significant bit to the most.
Completes and returns the checksum computation. The Checksum
object is reset to the initial state(state upon construction) when this
method completes.
Note:
ALG_ISO3309_CRC16 and ALG_ISO3309_CRC32 algorithms reset the initial checksum
value to 0. The initial checksum value can be re-initialized using the
init(byte[], short, short)
method.
The input and output buffer data may overlap.
In addition to returning ashort result, this method sets the
result in an internal state which can be rechecked using assertion methods
of the SensitiveResult class,
if supported by the platform.inBuff - the input buffer of data to be checksummedinOffset - the offset into the input buffer at which to begin checksum
generationinLength - the byte length to checksumoutBuff - the output buffer, may be the same as the input bufferoutOffset - the offset into the output buffer where the resulting checksum
value beginsoutBuffpublic abstract void update(byte[] inBuff,
short inOffset,
short inLength)
inOffset and continuing on until the byte at
(inOffset+inLength-1) of the inBuff array.
Within each byte the processing proceeds from the least significant bit
to the most.
This method requires temporary storage of intermediate results. This may
result in additional resource consumption and/or slow performance. This
method should only be used if all the input data required for the
checksum is not available in one byte array. The
doFinal(byte[], short, short, byte[], short)
method is recommended whenever possible.
Note:
inLength is 0 this method does nothing.
inBuff - the input buffer of data to be checksummedinOffset - the offset into the input buffer at which to begin checksum
generationinLength - the byte length to checksumdoFinalCopyright © 1998, 2015, Oracle and/or its affiliates. All rights reserved.