- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 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 命令值,如您所见,它们必须是 Optional
或 Custom
和支持,它们的作用取决于芯片。
您所说的 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/
使用登录后,我想吐出用户名。 但是,当我尝试单击登录按钮时, 它给了我力量。 我看着logcat,但是什么也没显示。 这种编码是在说。 它将根据我在登录屏幕中输入的名称来烘烤用户名。 不会有任何密码。
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎是题外话,因为它缺乏足够的信息来诊断问题。 更详细地描述您的问题或include a min
我是一名优秀的程序员,十分优秀!