模块  java.smartcardio
软件包  javax.smartcardio

Class CardChannel

    • 构造方法详细信息

    • 方法详细信息

      • getCard

        public abstract Card getCard()
        返回与此频道关联的卡片。
        结果
        此频道与之关联的卡片
      • getChannelNumber

        public abstract int getChannelNumber()
        返回此CardChannel的通道编号。 通道号0表示基本逻辑通道。
        结果
        此CardChannel的频道号。
        异常
        IllegalStateException - 如果此频道是 closed或相应的卡是 disconnected
      • transmit

        public abstract ResponseAPDU transmit​(CommandAPDU command)
                                       throws CardException
        将指定的命令APDU发送到智能卡并返回响应APDU。

        自动调整命令APDU的CLA字节以匹配该CardChannel的信道号。

        请注意,此方法不能用于传输MANAGE CHANNEL APDU。 应使用Card.openLogicalChannel()CardChannel.close()方法管理逻辑信道

        实现应该透明地处理传输协议的工件。 例如,当使用T = 0协议时,应按照ISO / IEC 7816-4中的描述进行以下处理:

        • 如果响应APDU的SW1为61 ,则实现应使用SW2作为Le字段发出GET RESPONSE命令。 只要收到61的SW1,就重复该过程。 这些交换的响应主体被连接起来形成最终的响应主体。

        • 如果响应APDU是6C XX ,则实现应该使用XX作为Le字段重新XX该命令。

        此方法返回的ResponseAPDU是执行此处理后的结果。

        参数
        command - 命令APDU
        结果
        响应APDU从卡收到
        异常
        IllegalStateException - 如果此频道是 closed或相应的卡是 disconnected
        IllegalArgumentException - 如果APDU编码 MANAGE CHANNEL命令
        NullPointerException - 如果command为null
        CardException - 如果卡操作失败
      • transmit

        public abstract int transmit​(ByteBuffer command,
                                     ByteBuffer response)
                              throws CardException
        传输存储在命令ByteBuffer中的命令APDU,并在响应ByteBuffer中接收响应APDU。

        命令缓冲区必须包含从command.position()开始的有效命令APDU数据,并且APDU必须为command.remaining()字节长。 返回时,命令缓冲区的位置将等于其限制; 它的限制不会改变。 输出缓冲区将收到响应APDU字节。 它的位置将按接收的字节数提前,这也是此方法的返回值。

        自动调整命令APDU的CLA字节以匹配该CardChannel的信道号。

        请注意,此方法不能用于传输MANAGE CHANNEL APDU。 应使用Card.openLogicalChannel()CardChannel.close()方法管理逻辑信道

        transmit()为响应APDU进行处理的讨论与SW1值616C

        参数
        command - 包含命令APDU的缓冲区
        response - 将从卡接收响应APDU的缓冲区
        结果
        接收到的响应APDU的长度
        异常
        IllegalStateException - 如果此频道是 closed或者相应的卡是 disconnected
        NullPointerException - 如果命令或响应为空
        ReadOnlyBufferException - 如果响应缓冲区是只读的
        IllegalArgumentException - 如果命令和响应是同一对象,如果 response可能没有足够的空间来接收响应APDU,或者如果APDU编码 MANAGE CHANNEL命令
        CardException - 如果卡操作失败
      • close

        public abstract void close()
                            throws CardException
        关闭此CardChannel。 通过发出MANAGE CHANNEL命令关闭逻辑通道,该命令应使用格式[xx 70 80 0n] ,其中n是此通道的通道编号, xx是编码此逻辑通道的CLA字节,并且所有其他位设置为0.此方法返回后,调用此类中的其他方法将引发IllegalStateException。

        请注意,使用此方法无法关闭基本逻辑通道。 可致电Card.disconnect(boolean)关闭。

        异常
        CardException - 如果卡操作失败
        IllegalStateException - 如果此CardChannel表示基本逻辑信道的连接