2

下面,您会看到一个程序,该程序用于在接收到任何 APDU 命令时返回 EEPROM 可用内存:

public class HelloWorld extends Applet {
    public static void install(byte[] bArray, short bOffset, byte bLength) {
        new helloWorld.HelloWorld().register(bArray, (short) (bOffset + 1),
                bArray[bOffset]);
    }

    public void process(APDU apdu) {
        if (selectingApplet()) {
            return;
        }

        getAvailableMem(apdu);

    }

    public void getAvailableMem(APDU apdu){
        byte[] buffer = apdu.getBuffer();
        short[] AvailableMem = {};

        UtilX.getAvailableMemoryInfo(AvailableMem, (short) 0,
                UtilX.MEMORY_TYPE_PERSISTENT);

        for(short i=0;i<(short)AvailableMem.length;i++){
            buffer[i]=(byte)AvailableMem[i];
        }

        apdu.setOutgoingAndSend((short)0, (short)(2*AvailableMem.length));
    }
}

但是当我向小程序发送 APDU 命令时,它返回0x6F00

OSC: opensc-tool -s 00a4040006010203040506 -s 00000000
Using reader with a card: ACS CCID USB Reader 0

Sending: 00 A4 04 00 06 01 02 03 04 05 06
Received (SW1=0x90, SW2=0x00)

Sending: 00 00 00 00
Received (SW1=0x6F, SW2=0x00)

请注意,我还使用以下循环尝试了上述程序:

for(byte i=0;i<(byte)AvailableMem.length;i++){
                buffer[i]=(byte)AvailableMem[i];
            }

它也编译成功!编译器不应该将数组索引的类型限制为byteonly 还是shortonly?为什么它接受两种类型的索引?

- 第二个程序在 OpenSCTool 中具有相同的输出。怎么了?

4

2 回答 2

2

您必须将结果存储到现有的非零长度数组中:

class MyApplet extends Applet {

short[] shorts = JCSystem.makeTransientShortArray((short)2, JCSystem.CLEAR_ON_RESET);

public void process(APDU apdu) {
    //...
    UtilX.getAvailableMemoryInfo(shorts, (short)0, UtilX.MEMORY_TYPE_PERSISTENT);
    //...
}

您的状态码6F00ArrayIndexOutOfBoundsException.

您可以将这两种整数类型用作索引:byte或者short,没有真正的区别(当然,对于不超过 0x7F 的数组)。

于 2015-03-18T11:12:30.117 回答
0

从我的一个小程序中取出的示例代码:

我上课开始时的声明

    short[] mem = new short[2];

从进程树内部:

case Cmd.GET_FREE_MEM:
                UtilX.getAvailableMemoryInfo(mem, (short) 0, UtilX.MEMORY_TYPE_PERSISTENT);
                Util.setShort(apdu.getBuffer(), (short) 0, mem[0]);
                Util.setShort(apdu.getBuffer(), (short) 2, mem[1]);
                UtilX.getAvailableMemoryInfo(mem, (short) 0, UtilX.MEMORY_TYPE_TRANSIENT_RESET);
                Util.setShort(apdu.getBuffer(), (short) 4, mem[0]);
                Util.setShort(apdu.getBuffer(), (short) 6, mem[1]);
                apdu.setOutgoingAndSend((short) 0, (short) 8);
                break;
于 2015-03-18T17:24:51.160 回答