访问超过2千字节的NFC标签内存

时间:2015-10-09 20:03:05

标签: android tags nfc rfid iso-15693

我需要开发一个Android应用程序,它能够读取包含大约8 kByte二进制数据的NfcV标记。单个标记块为8个字节。

我写了以下代码:

    for (int i = 0; i < 256; ++i)
    {
        byte[] cmd = new byte[] {
            0x02, 
            0x20,
            (byte)i          // Block number
        };
        byte[] block = nfcV.transceive(cmd);

        for(int j = 0; j < 8; ++j) this.sensorData[i * 8 + j] = block[j + 1];
    }

但是这让我只读取标签的前2 kByte(8个字节的256个块)。

如何读取所有8 kByte?

不幸的是,我对Tag的信息很少。我知道它是由德州仪器公司制造的,Taginfo应用程序说它与它兼容 ISO / IEC 15693-3和ISO / IEC 15693-2。

1 个答案:

答案 0 :(得分:1)

您正在使用READ SINGLE BLOCK命令(命令代码byte[] cmd = new byte[]{ (byte)0x08, //Protocol_Extension_flag=1 (byte)0x20, //READ SINGLE BLOCK (byte)(address & 0x00FF), (byte)((address>>8) & 0x00FF) }; )从ISO / IEC 15693标签中读取。该标准仅定义了从0到255的块地址的READ SINGLE BLOCK命令。因此,由于您的标记似乎具有8字节的块大小,因此该命令将您限制为标记存储器的前2 KB。

ISO / IEC 15693标准未定义超出此地址空间的读数。因此,这取决于您使用的标签类型,因此您应该查阅标签的用户手册。一些标签制造商通过定义协议扩展来克服这种地址空间限制(请参阅命令的请求标志字节中的Protocol_Extension_flag)

byte tagId = nfcV.getTag().getId();
byte[] cmd = new byte[]{
            (byte)0x28,  //Addressed_flag=1, Protocol_Extension_flag=1
            (byte)0x20,  //READ SINGLE BLOCK
            (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00,  // placeholder for UID
            (byte)(address & 0x00FF), (byte)((address>>8) & 0x00FF)
};
System.arraycopy(tagId, 0, cmd, 2, 8);

但是,这仅在您的标记支持此特定协议扩展时才有效。根据您的标签类型,标签还可以使用其他方法来处理剩余的内存。

另请注意,若干Android设备无法正常使用未解决的ISO / IEC 15693命令。因此,通常最好坚持使用已解决的命令版本。以上命令的寻址版本(Addressed_flag set和命令中包含的标记的UID)是这样的:

{{1}}

在上述两种情况下,您可以尝试Data_rate_flag(标志字节的第二低位)和Sub-carrier_flag(标志字节的最低位)的变体,但我不确定不同的Android设备将如何处理这个。