前言:好久前做了个开发SIM卡读写卡的项目, 研究了下ISO-7816协议, 整理了一些常用的APUD指令, 最近有时间, 决定把它记录下来.
传输协议
在SIM卡和ME的数据交互过程中,规定了T=0和T=1两种传输协议
命令头标由5个连续的字节组成:(T0)
CLA | INS | P1 | P2 | P3 |
---|
CLA: 命令类别,取值为“A0”,当CLA=FF时,为PPS过程的头标;
INS: 指令代码;
P1,P2: 指令附加参数;
P3: 由INS的编码而定,或是表示命令中送给SIM卡的数据长度,或是表示等待从SIM卡响应的数据最大长度。
注释: 也就是说将这些拼接上A0+INS+P1+P2+P3
举例: A0A40000023F00(进入到3F00文件, 其中A4是命令, 相当于终端中用cd进入文件位置一样)
文件标识符
- 3F:主文件;
- 7F:第一级专有文件
- 5F:第二级专有文件
- 2F:主文件下的基本文件
- 6F:在第一级专有文件下的基本文件
- 4F:在第二级专有文件下的基本文件
判断SIM卡是否是白卡
A0A40000023F00 // 进入3F00主文件
A0A40000027F20 // 进入7F20文件
A0A40000026F07 // 进入6F07文件
A0B0000009 // B0 允许SIM卡从当前透明文件中读取字节串
// 返回的字符串
str = [str substringWithRange:NSMakeRange(0, 18)];
if ([str isEqualToString:@"FFFFFFFFFFFFFFFFFF"]) {
// 为白卡
return YES;
}
读取短信中心
A0A40000023F00
A0A40000027F10
A0A40000026F42
A0C000000F
A0B2010428 // B2 用于读取线性固定文件或循环文件的记录
读取iccid
A0A40000023F00
A0A40000022FE2
A0B000000A
// 返回的卡号为倒序卡号
读取IMSI号
A0A40000023F00
A0A40000027F20
A0A40000026F07
A0B0000009
以上就是本次内容了, 遵循SIM卡规范国际标准,写卡我这里就不说了, 希望对初次接触SIM卡的小伙伴有所帮助.
喜欢的小伙伴点个喜欢或关注吧, 你们的鼓励是我前进的动力!
网友评论