READ BINARYAPDU允许 2 个字节的文件偏移量,用P1和P2编码,并使用Le表示长度,
READBINARY以表示响应中的字节数。P1是 高字节 或最高有效字节。但是,保留P1的最高位以指示P1是否还包含 短文件标识符
。
0如果您已经在读取文件,则该值应保持不变,最大偏移量为32Ki-1。
我看不到您链接的规格,但假设
READ BINARY卡上的APDU的工作方式相同。
您的读取前256个字节的命令似乎是正确的,注意这
Le==0x00表示已读取256个字节。
要读取以偏移量256、512等开头的字节,请开始递增P1,例如:
00 B0 01 00 0000 B0 02 00 0000 B0 03 00 00
要读取从偏移量257(0x101)开始的256个字节,请执行以下操作:
00 B0 01 01 00
偏移600(0x258):
00 B0 02 58 00
在您的代码中,如果您使用Java
int存储偏移量,通常会以如下所示结束P1的递增:
int offset;int P1, P2;while (continueReading){ // ... P1 = (offset >> 8) & 0xFF; P2 = offset & 0x00FF; // ... // send APDU}如何指示文件的大小取决于实现方式。通常,您可以从EF(
00 A4 00 00 02fileId)上的SELECT返回的文件控制信息(FCI)结构中获取文件大小。但是,文件的大小也可以嵌入文件的内容中。如果可能的话,您不应依靠状态字来告诉您文件的大小。
加法:Le,Ne和奇数INS
重要的是只增加响应数据(RDATA)中 实际接收 的字节数的偏移量。注意,如果P3 = Le,则Le编码Ne,Ne是响应数据的 最大
大小。您收到的可能少于该数。
如果文件大小为32Ki或更大,则需要使用READ
BINARY和奇数INS(
B7)来读取32Ki以上的数据。在那种情况下,RDATA也可能包含开销。显然,这反过来可能会影响偏移量计算以及要读取到文件末尾的计算。



