Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/210.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/kotlin/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 访问超过2k字节的NFC标记内存_Android_Tags_Nfc_Rfid_Iso 15693 - Fatal编程技术网

Android 访问超过2k字节的NFC标记内存

Android 访问超过2k字节的NFC标记内存,android,tags,nfc,rfid,iso-15693,Android,Tags,Nfc,Rfid,Iso 15693,我需要开发一个Android应用程序,能够读取包含约8KB二进制数据的NfcV标记。单个标记块为8个字节 我编写了以下代码: for (int i = 0; i < 256; ++i) { byte[] cmd = new byte[] { 0x02, 0x20, (byte)i // Block number }; byte[] bl

我需要开发一个Android应用程序,能够读取包含约8KB二进制数据的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];
    }
for(int i=0;i<256;++i)
{
字节[]cmd=新字节[]{
0x02,
0x20,
(字节)i//块号
};
字节[]块=nfcV.收发器(cmd);
对于(int j=0;j<8;++j),此.sensorData[i*8+j]=块[j+1];
}
但这只允许我读取标记的前2kbyte(256块8字节)

如何读取所有8KB的数据

不幸的是,我几乎没有关于标签的信息。我知道它是由德州仪器公司生产的,Taginfo应用程序说它与
ISO/IEC 15693-3和ISO/IEC 15693-2。

您使用读取单块命令(命令代码
0x20
)读取ISO/IEC 15693标记。该标准仅为从0到255的块地址定义读取单个块命令。因此,由于标记的块大小似乎为8字节,因此此命令将标记内存限制为前2kb

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

但是,只有当您的标记支持此特定的协议扩展时,这才起作用。根据标记类型,标记也可能使用其他方法来寻址剩余内存

还要注意的是,一些Android设备将无法正常使用未寻址的ISO/IEC 15693命令。因此,通常最好坚持使用已寻址的命令版本。上述命令的寻址版本(命令中包含的已寻址标志集和标记的UID)如下所示:

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);

在上述两种情况下,您都可以尝试Data_rate_标志(标志字节的第二低位)和Sub-carrier_标志(标志字节的最低位)的变化,尽管我不确定不同的Android设备将如何处理此问题。

发送命令[0x08,0x20]会导致“Tag was lost”异常,这听起来很奇怪,因为在未接受命令的情况下,我希望返回值为[0x01,0x02](“未识别命令”),而不是异常?@CarloCecchi您可能希望尝试将标志字节设置为0x0A。(您可能想尝试该命令的寻址版本。)我尝试了0x02、0x08和0x20位的所有组合,但除了0x02之外,我总是收到一个“Tag was lost”错误。你能给我解释一下地址是什么意思吗?我没有抓住这一点。谢谢。@carlocechi Addressed表示您将标记的“地址”(序列号)添加到命令中。有关命令的寻址版本,请参见我的编辑。
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);