我想了解 NfcV ISO-15639 的操纵

I would like to understand the manipulation of NfcV ISO-15639

我是 NFC 技术新手!

我很难理解如何操作方块。

  byte[] cmd = new byte[] {
     (byte)0x20, //FLAG
     (byte)0x21, //WRITE SINGLE BLOCK COMMAND
     (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, //UID
     (byte)0x00, //OFFSET
     (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00 //DATA
   };

我对上面代码的问题:

什么是FLAG,它的作用是什么?

什么是 UID,它的作用是什么?在代码中,UID 行有 8 "index",是否可以增加或减少大小?而不是代码中的 8,减少到 6 或增加到 10?

什么是OFFSET,它的作用是什么?

在注释代码的第 6 行作为 DATA,这是我定义块的字节大小的地方吗?在代码中,它有 4 个索引,是否意味着我存储在块中的数据将有 4 个字节?我可以增加还是减少?

让我们假设,我有一个4字节的数据myData = "ABCD",我想把这个数据写入我标签的块04,根据上面提到的代码我该怎么做?

我不是 NfcV 专家,但以下是我对标签和低级访问的了解

Flag字节是什么意思? - 未知但 http://www.ti.com/lit/an/sloa141/sloa141.pdf 第 4.1 节包含 ISO 15693 标志含义的详细信息

但是其中一个标志意味着使用寻址或未寻址模式,这导致了 UID

什么是 UID 字节 - 大多数标签都有序列号或唯一标识符号

在寻址模式下,您必须提供正在读取或写入的卡的正确 UID 才能成功。这意味着您不会写入或读取错误的卡。有命令先从卡中读取UID

在未寻址模式下,UID 提供为零

你已经计算出第二个字节是 0x21 用于写命令。

0x20 读取命令

http://www.ti.com/lit/an/sloa141/sloa141.pdf 第 4.2 节包含 ISO 15693 命令值的详细信息,如您所见,它们必须是 OptionalCustom,支持以及它们的作用取决于芯片。

你所说的 OFFSET 是内存块从第一个块开始的偏移量,或者更好地描述为内存地址(把它想象成一本书中的页码)。大多数芯片将内存分成固定大小的块。有些芯片使用单个字节作为内存地址,有些则使用 2 个字节。

每个块都是固定数量的字节,通常是 4 个字节,但我看过芯片规格是 128 个字节。

您在问题中提供的数据结构通常用作您尝试与之通信的芯片的格式良好的命令模板。

示例中的 DATA 4 个字节只是您要写入的实际数据的占位符,您应该在发送命令之前将要写入的实际 4 个字节复制到模板中。

因此,当您使用它进行写入时,您必须将 OFFSET/Memory Address 调整为 "right page of the book" 并复制正确数量的 "letters"可以在页面上写到模板的DATA部分

https://www.st.com/content/ccc/resource/technical/document/application_note/group0/76/0e/00/a0/1b/04/4c/f2/DM00103491/files/DM00103491.pdf/jcr:content/translations/en.DM00103491.pdf

末尾可以看到来自芯片制造商的Android的一些NfcV代码示例

所以最后一题Lets go suppose, i have a 4 bytes data myData = "ABCD", and i want to write this data to block 04 of my tag

构造命令的例子


// Command Template
byte[] cmd = new byte[] {
     (byte)0x20, //FLAG
     (byte)0x21, //WRITE SINGLE BLOCK COMMAND
     (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00, //UID
     (byte)0x00, //OFFSET
     (byte)0x00, (byte)0x00, (byte)0x00, (byte)0x00 //DATA
   };

// The data to be written
String myData = "ABCD";
// Get the data as bytes
byte[] data = myData.getBytes();

// Change the "OFFSET" / "Block number" to the the fourth Block
// If that what was meant by "block 04"
// The addresses start at Zero and the byte array starts at zero
// So the "Block Number" is the 11th byte in the command
cmd[10] = (byte)((3) & 0x0ff);

// Copy in 4 bytes of data in to bytes 11 to 15
// Starting at byte 0 in the data array
System.arraycopy(data,  0, cmd, 11, 4);


参考 arraycopy 参数 https://docs.oracle.com/javase/7/docs/api/java/lang/System.html#arraycopy(java.lang.Object,%20int,%20java.lang.Object,%20int,%20int)