java.lang.Object | |
↳ | javax.smartcardio.CommandAPDU |
A command APDU following the structure defined in ISO/IEC 7816-4. It consists of a four byte header and a conditional body of variable length. This class does not attempt to verify that the APDU encodes a semantically valid command.
Note that when the expected length of the response APDU is specified
in the constructors
,
the actual length (Ne) must be specified, not its
encoded form (Le). Similarly, getNe()
returns the actual
value Ne. In other words, a value of 0 means "no data in the response APDU"
rather than "maximum length."
This class supports both the short and extended forms of length encoding for Ne and Nc. However, note that not all terminals and Smart Cards are capable of accepting APDUs that use the extended form.
For the header bytes CLA, INS, P1, and P2 the Java type int
is used to represent the 8 bit unsigned values. In the constructors, only
the 8 lowest bits of the int
value specified by the application
are significant. The accessor methods always return the byte as an unsigned
value between 0 and 255.
Instances of this class are immutable. Where data is passed in or out via byte arrays, defensive cloning is performed.
Public Constructors | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Constructs a CommandAPDU from a byte array containing the complete
APDU contents (header and body).
| |||||||||||
Constructs a CommandAPDU from a byte array containing the complete
APDU contents (header and body).
| |||||||||||
Creates a CommandAPDU from the ByteBuffer containing the complete APDU
contents (header and body).
| |||||||||||
Constructs a CommandAPDU from the four header bytes.
| |||||||||||
Constructs a CommandAPDU from the four header bytes and the expected
response data length.
| |||||||||||
Constructs a CommandAPDU from the four header bytes and command data.
| |||||||||||
Constructs a CommandAPDU from the four header bytes and command data.
| |||||||||||
Constructs a CommandAPDU from the four header bytes, command data,
and expected response data length.
| |||||||||||
Constructs a CommandAPDU from the four header bytes, command data,
and expected response data length.
|
Public Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Compares the specified object with this command APDU for equality.
| |||||||||||
Returns a copy of the bytes in this APDU.
| |||||||||||
Returns the value of the class byte CLA.
| |||||||||||
Returns a copy of the data bytes in the command body.
| |||||||||||
Returns the value of the instruction byte INS.
| |||||||||||
Returns the number of data bytes in the command body (Nc) or 0 if this
APDU has no body.
| |||||||||||
Returns the maximum number of expected data bytes in a response
APDU (Ne).
| |||||||||||
Returns the value of the parameter byte P1.
| |||||||||||
Returns the value of the parameter byte P2.
| |||||||||||
Returns the hash code value for this command APDU.
| |||||||||||
Returns a string representation of this command APDU.
|
[Expand]
Inherited Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
![]() |
Constructs a CommandAPDU from a byte array containing the complete APDU contents (header and body).
Note that the apdu bytes are copied to protect against subsequent modification.
apdu | the complete command APDU |
---|
NullPointerException | if apdu is null |
---|---|
IllegalArgumentException | if apdu does not contain a valid command APDU |
Constructs a CommandAPDU from a byte array containing the complete
APDU contents (header and body). The APDU starts at the index
apduOffset
in the byte array and is apduLength
bytes long.
Note that the apdu bytes are copied to protect against subsequent modification.
apdu | the complete command APDU |
---|---|
apduOffset | the offset in the byte array at which the apdu data begins |
apduLength | the length of the APDU |
NullPointerException | if apdu is null |
---|---|
IllegalArgumentException | if apduOffset or apduLength are negative or if apduOffset + apduLength are greater than apdu.length, or if the specified bytes are not a valid APDU |
Creates a CommandAPDU from the ByteBuffer containing the complete APDU
contents (header and body).
The buffer's position
must be set to the start of the APDU,
its limit
to the end of the APDU. Upon return, the buffer's
position
is equal to its limit; its limit remains unchanged.
Note that the data in the ByteBuffer is copied to protect against subsequent modification.
apdu | the ByteBuffer containing the complete APDU |
---|
NullPointerException | if apdu is null |
---|---|
IllegalArgumentException | if apdu does not contain a valid command APDU |
Constructs a CommandAPDU from the four header bytes. This is case 1 in ISO 7816, no command body.
cla | the class byte CLA |
---|---|
ins | the instruction byte INS |
p1 | the parameter byte P1 |
p2 | the parameter byte P2 |
Constructs a CommandAPDU from the four header bytes and the expected response data length. This is case 2 in ISO 7816, empty command data field with Ne specified. If Ne is 0, the APDU is encoded as ISO 7816 case 1.
cla | the class byte CLA |
---|---|
ins | the instruction byte INS |
p1 | the parameter byte P1 |
p2 | the parameter byte P2 |
ne | the maximum number of expected data bytes in a response APDU |
IllegalArgumentException | if ne is negative or greater than 65536 |
---|
Constructs a CommandAPDU from the four header bytes and command data.
This is case 3 in ISO 7816, command data present and Ne absent. The
value Nc is taken as data.length. If data
is null or
its length is 0, the APDU is encoded as ISO 7816 case 1.
Note that the data bytes are copied to protect against subsequent modification.
cla | the class byte CLA |
---|---|
ins | the instruction byte INS |
p1 | the parameter byte P1 |
p2 | the parameter byte P2 |
data | the byte array containing the data bytes of the command body |
IllegalArgumentException | if data.length is greater than 65535 |
---|
Constructs a CommandAPDU from the four header bytes and command data.
This is case 3 in ISO 7816, command data present and Ne absent. The
value Nc is taken as dataLength. If dataLength
is 0, the APDU is encoded as ISO 7816 case 1.
Note that the data bytes are copied to protect against subsequent modification.
cla | the class byte CLA |
---|---|
ins | the instruction byte INS |
p1 | the parameter byte P1 |
p2 | the parameter byte P2 |
data | the byte array containing the data bytes of the command body |
dataOffset | the offset in the byte array at which the data bytes of the command body begin |
dataLength | the number of the data bytes in the command body |
NullPointerException | if data is null and dataLength is not 0 |
---|---|
IllegalArgumentException | if dataOffset or dataLength are negative or if dataOffset + dataLength are greater than data.length or if dataLength is greater than 65535 |
Constructs a CommandAPDU from the four header bytes, command data,
and expected response data length. This is case 4 in ISO 7816,
command data and Ne present. The value Nc is taken as data.length
if data
is non-null and as 0 otherwise. If Ne or Nc
are zero, the APDU is encoded as case 1, 2, or 3 per ISO 7816.
Note that the data bytes are copied to protect against subsequent modification.
cla | the class byte CLA |
---|---|
ins | the instruction byte INS |
p1 | the parameter byte P1 |
p2 | the parameter byte P2 |
data | the byte array containing the data bytes of the command body |
ne | the maximum number of expected data bytes in a response APDU |
IllegalArgumentException | if data.length is greater than 65535 or if ne is negative or greater than 65536 |
---|
Constructs a CommandAPDU from the four header bytes, command data,
and expected response data length. This is case 4 in ISO 7816,
command data and Le present. The value Nc is taken as
dataLength
.
If Ne or Nc
are zero, the APDU is encoded as case 1, 2, or 3 per ISO 7816.
Note that the data bytes are copied to protect against subsequent modification.
cla | the class byte CLA |
---|---|
ins | the instruction byte INS |
p1 | the parameter byte P1 |
p2 | the parameter byte P2 |
data | the byte array containing the data bytes of the command body |
dataOffset | the offset in the byte array at which the data bytes of the command body begin |
dataLength | the number of the data bytes in the command body |
ne | the maximum number of expected data bytes in a response APDU |
NullPointerException | if data is null and dataLength is not 0 |
---|---|
IllegalArgumentException | if dataOffset or dataLength are negative or if dataOffset + dataLength are greater than data.length, or if ne is negative or greater than 65536, or if dataLength is greater than 65535 |
Compares the specified object with this command APDU for equality. Returns true if the given object is also a CommandAPDU and its bytes are identical to the bytes in this CommandAPDU.
obj | the object to be compared for equality with this command APDU |
---|
Returns a copy of the bytes in this APDU.
Returns the value of the class byte CLA.
Returns a copy of the data bytes in the command body. If this APDU as no body, this method returns a byte array with length zero.
Returns the value of the instruction byte INS.
Returns the number of data bytes in the command body (Nc) or 0 if this
APDU has no body. This call is equivalent to
getData().length
.
Returns the maximum number of expected data bytes in a response APDU (Ne).
Returns the value of the parameter byte P1.
Returns the value of the parameter byte P2.
Returns the hash code value for this command APDU.
Returns a string representation of this command APDU.