gpt4 book ai didi

android - 我想了解 NfcV ISO-15639 的操纵

转载 作者:行者123 更新时间:2023-11-29 22:44:52 24 4
gpt4 key购买 nike

我是 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?

什么是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 标志含义的详细信息

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

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

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

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

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

0x20 读命令

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

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

每个 block 都是固定数量的字节,通常是 4 个字节,但我看到芯片规范是 128 个字节。

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

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

所以当你用它写的时候,你必须调整OFFSET/Memory Address为“书的右页”并复制到正确的数字可以写在页面上的“字母”到模板的 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代码的一些示例。

所以最后一个问题让我们假设,我有一个 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com