一个APDU可以是一个命令,也可以是命令的响应。
命令APDU的一般格式:
CLA INS P1 P2 P3 Data
响应APDU的一般格式:
Data SW1 SW2
各个字节的意义如下:
CLA: 是指令类型,GSM应用为0xA0。
INS:每个命令的指令编码,下面有定义。
P1,P2,P3:指令参数。0xFF是个无效值,P3给出了数据单元的长度。对于传送命令,当SIM 流出数据时,P3=0表示数据的长度为256,而SIM 流入数据时P3=0表 示没有数据。
SW1,SW2:命令结果是否成功的状态。
指令的5种情况
情况1:没有输入/没有输出
CLA INS P1 P2 P3(lgth=0x00)
SW1=0x90 SW2=0x00
情况2:没有输入/输出长度已知
CLA INS P1 P2 P3(长度值lgth)
DATA(长度为lgth) SW1=0x90 SW2=0x00
情况3:没有输入/输出长度未知
CLA INS P1 P2 P3(lgth=0)
SW1=0x9F SW2=lgth1
GET RESPONSE
CLA INS P1 P2 P3(lgth2)
DATA(长度leth1<=leth2) SW1=0x90 SW2=0x00
情况4:有输入/没有输出
CLA INS P1 P2 P3(lgth)
DATA(长度为lgth) SW1=0x90 SW2=0
情况5:有输入/输出长度未知或已知
CLA INS P1 P2 P3(lgth)
DATA(长度为lgth) SW1=0x9F SW2=lgth1
GET RESPONSE
CLA INS P1 P2 P3(lgth2)
DATA(长度lgth2<=lgth1) SW1=0x90 SW2=0x00
11.11中命令集如下:
(1) SELECT
选择一个文件的方法:
例:
CLA=A0:表示GSM应用
INS=A4:表示SELECT
P1P2=0000:表示参数
P3=02:表示输入文件ID的长度
3F00,7F10,6F3A表示选择的文件ID
SW1=9F SW2=17(23)/0F(15)表示命令正确结束,其中SW2表示响应值长度
(2) STATUS
例:
CLA=A0:表示GSM应用
INS=F2:表示STATUS
P1P2=0000:表示参数
P3=22:表示返回响应值长度(从SELECT的返回值中获取)
SW1=90 SW2=00 表示命令正确结束
00005DD07F1002000000000015B10114060085838583000083830000000000000000表示返回的响应值(响应的参数/数据同使用SELECT命令选中MF和DF时的响应数据相同。)
(3) GET RESPONSE
(4)READ BINARY
//SELECT
A0 A4 00 00 02 2F05
9F 0F
//GET RESPONSE
A0 C0 00 00 0F
0000 0008 2F05 04 00 01FF55 01 02 0000
90 00
//READ BINARY
A0 B0 00 00 08
6573656E66727074
90 00
//READ BINARY
A0 B0 00 01 04
73656E66
90 00
CLA=A0:表示GSM应用
INS=B0:表示READ BINARY
P1P2=0000:表示高低位偏移
P3=08:表示返回响应值长度(从SELECT的返回值中获取)
(当P1P2=0001,P3=04时表示向右偏移1位,返回长度为4的响应值)
SW1=90 SW2=00 表示命令正确结束
(5)UPDATE BINARY
//SELECT
A0 A4 00 00 02 2F05
9F 0F
//GET RESPONSE
A0 C0 00 00 0F
0000 0008 2F05 04 00 01FF55 01 02 0000
90 00
//READ BINARY
A0 B0 00 00 08
6573656E66727074
90 00
//UPDATE BINARY
A0 D6 00 00 08
0000000000000001
90 00
//READ BINARY
A0 B0 00 00 08
0000000000000001
90 00
更新成功!
(6)READ RECORD
此功能用于读取线性固定文件或循环文件的记录;
如果不满足EF文件READ指令的访问准予条件,SIM卡拒绝该功能。若操作失败,记录指针不改变;
读指令定义了4种模式:
CURRENT模式(04):读当前的记录,记录指针不变;
ABSOLUTE模式(04+记录号):读给定记录号的记录,记录指针不变;
NEXT模式(02):功能执行前记录指针加一,然后读取指针指向的记录。
PREVIOUS模式(03):功能执行前记录指针减一,然后读取指针指向的记录。
输入:模式、记录号(ABSOLUTE模式)、记录长度;
输出:记录;
//SELECT
A0A4000002 3F00
9F17
//SELECT
A0A4000002 7F10
9F17
//SELECT
A0A4000002 6F3A
9F0F
//GET RESPONSE
A0C000000F
00000AF06F3A040011FF440102011C
9000
//READ RECORD
A0B201041C
80aabbccddFFFFFFFFFFFFFFFFFF07812143658709F1FFFFFFFFFFFF
9000
(7)UPDATE RECORD
//SELECT
A0A4000002 3F00
9F17
//SELECT
A0A4000002 7F10
9F17
//SELECT
A0A4000002 6F3A
9F0F
//GET RESPONSE
A0C000000F
00000AF06F3A040011FF440102011E
9000
//UPDATE RECORD
A0DC01041E
输入数据:
111110000000000000000000000000000000000000000000000000000000
90 00