我在使用 MIFARE DESFire 时遇到了一个非常奇怪的问题。当我写入少量数据(例如11字节)时,写入操作成功。然而,当我尝试写例如50字节,响应为917E,说明命令存在长度问题。
尝试写入11个字节:
<-- 90 3D 00 00 12 01 000000 0B0000 1234567890AABBCC DDEEFF 00 --> 9100 (success)
尝试写入 50 个字节:
<-- 90 3D 00 00 39 01 000000 320000 1234567890AABBCC DDEE1234567890AA BBCCDDEE12345678 90AABBCCDDEE1234 567890AABBCCDDEE 1234567890AABBCC DDEE 00 --> 917E (length error)
最佳答案
该错误表明您的命令太长。您可能使用 DESFire EV1,它仅支持最大 55 字节的包装 APDU 长度。因此,当以包装 native 模式打包到单个 APDU 中时,WriteData 命令的最大数据长度为
55 - APDU Header - APDU Lc - File ID - Offset - Length - APDU Le = 55 - 4 - 1 - 1 - 3 - 3 - 1 = 42 bytes.
由于 APDU 包装,该值略小于 WriteData 命令本身的限制。请注意,您仍然可以通过将数据拆分到多个 DESFire 帧(使用 0xAF 状态和命令代码),在一个 WriteData 命令中发送(更多)更多数据。
更新
DESFire EV1 数据表中提到了 55 个字节。实际测试vikky据透露,这实际上可能是 60 字节(导致最大数据长度为 47 字节)。
关于smartcard - DESFire 写入数据命令失败,出现 917E(长度错误),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48220818/