1

我是 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 个“索引”,是否可以增加或减少大小?而不是代码中的 8,减少到 6 或增加到 10?

什么是偏移量,它的功能是什么?

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

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

4

1 回答 1

1

我不是 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 个字节。

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

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

因此,当您使用它进行写作时,您必须将OFFSET/调整Memory Address为“书的正确页面”,并将可以在页面上写入的正确数量的“字母”复制到DATA模板的一部分

在https://www.st.com/content/ccc/resource/technical/document/application_note/group0/76/0e/00/a0/的末尾可以看到来自芯片制造商的一些适用于 Android 的 NfcV 代码示例1b/04/4c/f2/DM00103491/files/DM00103491.pdf/jcr:content/translations/en.DM00103491.pdf

所以最后一个问题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)

于 2019-10-31T21:16:55.730 回答