欢迎光临,嵌入式开源博客

PNP532 NFC P2P方法代码-PNP532命令抓包方式发送

最近项目用到了PNP532,官方提供了库,使用的是libnfc,但出于速度,本着使用简单就没研读具体的协议。
也是为了再各个平台方便移植。
思路是通过串口的方式用上位机进行P2P的方式,通过串口监测软件进行抓包,然后写一个简单的程序按照抓包的顺序发送数据,大多数的 数据帧都是固定的。除了你要发送的数据需要特殊拼帧。
下面是简单的方法封装:

对于需要发送的数据如何进行封装,下面这个帖子有详细的介绍,也很简单。方便浏览 我搬过来了:
原文链接:https://blog.csdn.net/roctwo/article/details/78743259

1.PREAMBLE1 byte4,

这个就是所谓的帧头,也称为前导码,一般是00
2.START CODE2 bytes (0x00 and 0xFF),

开始码 2个字节,分别是 00和FF
3.LEN1 byte indicating the number of bytes in the data field
(TFI and PD0 to PDn),

这个是数据长度,一个TFI和n个PD
3.LCS1 Packet Length Checksum LCS byte that satisfies the relation:
Lower byte of [LEN + LCS] = 0x00,

这个是LEN的补码,也就是(LEN取反+1)
4.TFI1 byte frame identifier, the value of this byte depends
on the way of the message
– D4h in case of a frame from the host controller to the PN532,
– D5h in case of a frame from the PN532 to the host controller.

表示数据流向 D4 表示 数据发向PN532

D5 表示 PN532数据发出
5.DATALEN-1 bytes of Packet Data Information
The first byte PD0 is the Command Code,

搞了半天,这才是我们想要发的数据,DATA的第一个字节PD0为控制字符,其余为普通数据。该包长度为 LEN-1
6.DCS1 Data Checksum DCS byte that satisfies the relation:
Lower byte of [TFI + PD0 + PD1 + … + PDn + DCS] = 0x00,

DCS 其实最坑了,根本不知道怎么算出来的。其实就是把这些十六进制数加起来,后两位取补码即可。即(TFI + PD0 + PD1 + … + PDn)累加和,取后两位的补码。
POSTAMBLE1 byte2.

帧尾 一般为 00
The amount of data that can be exchanged using this frame structure is limited to 255
bytes (including TFI).
这种的数据结构只能有255 个data (包括TFI)

赞(0) 打赏
未经允许不得转载:Huangea Blog 嵌入式博客 » PNP532 NFC P2P方法代码-PNP532命令抓包方式发送
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

一个很有意思的网站

留言板友链

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏