public abstract class CardChannel extends Object
Card,
CommandAPDU,
ResponseAPDU
| Modifier | Constructor and Description |
|---|---|
protected |
CardChannel()
Constructs a new CardChannel object.
|
| Modifier and Type | Method and Description |
|---|---|
abstract void |
close()
Closes this CardChannel.
|
abstract Card |
getCard()
Returns the Card this channel is associated with.
|
abstract int |
getChannelNumber()
Returns the channel number of this CardChannel.
|
abstract int |
transmit(ByteBuffer
Transmits the command APDU stored in the command ByteBuffer and receives the response APDU in the response ByteBuffer.
|
abstract ResponseAPDU |
transmit(CommandAPDU
Transmits the specified command APDU to the Smart Card and returns the response APDU.
|
protected CardChannel()
This constructor is called by subclasses only. Application should call the Card
public abstract CardgetCard()
public abstract int getChannelNumber()
IllegalStateException - if this channel has been
closed or if the corresponding Card has been
disconnected.
public abstract ResponseAPDUtransmit(CommandAPDU command) throws CardException
The CLA byte of the command APDU is automatically adjusted to match the channel number of this CardChannel.
Note that this method cannot be used to transmit MANAGE CHANNEL APDUs. Logical channels should be managed using the Card
Implementations should transparently handle artifacts of the transmission protocol. For example, when using the T=0 protocol, the following processing should occur as described in ISO/IEC 7816-4:
if the response APDU has an SW1 of 61, the implementation should issue a GET RESPONSE command using SW2 as the Lefield. This process is repeated as long as an SW1 of 61 is received. The response body of these exchanges is concatenated to form the final response body.
if the response APDU is 6C XX, the implementation should reissue the command using XX as the Le field.
The ResponseAPDU returned by this method is the result after this processing has been performed.
command - the command APDU
IllegalStateException - if this channel has been
closed or if the corresponding Card has been
disconnected.
IllegalArgumentException - if the APDU encodes a
MANAGE CHANNEL command
NullPointerException - if command is null
CardException - if the card operation failed
public abstract int transmit(ByteBuffercommand, ByteBuffer response) throws CardException
The command buffer must contain valid command APDU data starting at command.position() and the APDU must be command.remaining() bytes long. Upon return, the command buffer's position will be equal to its limit; its limit will not have changed. The output buffer will have received the response APDU bytes. Its position will have advanced by the number of bytes received, which is also the return value of this method.
The CLA byte of the command APDU is automatically adjusted to match the channel number of this CardChannel.
Note that this method cannot be used to transmit MANAGE CHANNEL APDUs. Logical channels should be managed using the Card
See transmit() for a discussion of the handling of response APDUs with the SW1 values 61 or 6C.
command - the buffer containing the command APDU
response - the buffer that shall receive the response APDU from the card
IllegalStateException - if this channel has been
closed or if the corresponding Card has been
disconnected.
NullPointerException - if command or response is null
ReadOnlyBufferException - if the response buffer is read-only
IllegalArgumentException - if command and response are the same object, if
response may not have sufficient space to receive the response APDU or if the APDU encodes a
MANAGE CHANNEL command
CardException - if the card operation failed
public abstract void close()
throws CardException
MANAGE CHANNEL command that should use the format
[xx 70 80 0n] where
n is the channel number of this channel and
xx is the
CLA byte that encodes this logical channel and has all other bits set to 0. After this method returns, calling other methods in this class will raise an IllegalStateException.
Note that the basic logical channel cannot be closed using this method. It can be closed by calling Card.
CardException - if the card operation failed
IllegalStateException - if this CardChannel represents a connection the basic logical channel