我是 NFC 技术新手!
我很难理解如何操作 block 。
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 个“索引”,是否可以增加或减少大小?减少到 6 或增加到 10,而不是代码中的 8?
什么是OFFSET及其功能是什么?
在作为 DATA 的注释代码的第 6 行中,这是我定义 block 的字节大小的地方吗?在代码中,它有4个索引,这是否意味着我存储在 block 中的数据将有4个字节?我可以增加或减少吗?
让我们假设,我有一个 4 字节数据 myData = "ABCD"
,我想将此数据写入我的标签的 block 04,我将如何根据提到的代码执行此操作上面?
最佳答案
我不是 NfcV 专家,但以下是我对标签和低级访问的了解
Flag
字节是什么意思? - 未知但http://www.ti.com/lit/an/sloa141/sloa141.pdf第 4.1 节详细介绍了 ISO 15693 标志含义
但是其中一个Flag表示使用寻址或非寻址模式,这会导致UID
什么是UID
字节 - 大多数标签都有序列号或唯一标识符号
在寻址模式下,您必须提供正在读取或写入的卡的正确 UID 才能成功。这意味着您不会在错误的卡上写入或读取。有一个命令是先从卡中读取UID。
在非寻址模式下,UID 为零
您已经计算出写入命令的第二个字节是 0x21
。
0x20
用于读取命令
http://www.ti.com/lit/an/sloa141/sloa141.pdf第 4.2 节详细介绍了 ISO 15693 命令值,如您所见,它们必须是可选
或自定义
和支持,它们的作用取决于芯片。
OFFSET 正如你所说,是内存块相对于第一个 block 的偏移量,或者更好地描述为内存地址(可以将其想象为书本中的页码)。大多数芯片将内存分成固定大小的 block 。有些芯片使用单字节作为内存地址,有些芯片使用 2 个字节。
每个 block 都是一定数量的字节,通常为 4 字节,但我见过芯片规范为 128 字节。
您在问题中给出的数据结构通常用作您尝试与之通信的芯片的格式良好的命令的模板。
示例中的 DATA
4 个字节只是您要写入的实际数据的占位符,您应该在发送命令之前将要写入的实际 4 个字节复制到模板中.
因此,当您使用它进行写入时,您必须将 OFFSET
/Memory Address
调整为“书的正确页”并复制正确的编号可以在页面上写入模板的DATA
部分的“字母”
来自芯片制造商的 Android NfcV 代码的一些示例可以在 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 的末尾看到。
所以最后一个问题让我们假设,我有一个 4 字节数据 myData = "ABCD",我想将此数据写入我的标签的 block 04
构造命令的示例
// 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)
关于android - 我想了解 NfcV ISO-15639 的操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58630929/