下面,您将看到一个程序,用于在接收任何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));
}
}
但是当我向applet发送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];
}
它也成功编译!编译器是否应该仅将数组索引的类型限制为byte
或仅限short
?为什么它接受两种类型的索引?
- 这个第二个程序在OpenSCTool中具有相同的输出。 怎么了?
答案 0 :(得分: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);
//...
}
您的状态代码6F00
是ArrayIndexOutOfBoundsException
的未捕获实例。
您可以将两种整数类型用作索引:byte
或short
,没有实际区别(当然,对于不超过0x7F的数组)。
答案 1 :(得分:0)
从我的一个applet中取出示例代码:
我班级开头的宣言
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;