如何将 URL 正确编码到 NFC 标签上?

How to properly encode a URL onto an NFC tag?

我有一张 Mifare ULC 卡。当我将此卡轻触支持 NFC 的设备时,它应该在 phone 中打开默认浏览器,而无需任何其他 NFC 应用程序。

我已经将以下 NDEF URL 数据编码到标签中,但是当我扫描标签时,它没有打开浏览器。谁能指导我哪里做错了?

03 - tag for the NDEF
12 - length of the NDEF msg (18 Bytes)
D3    Record header (of first and only record)
      Bit 7 = MB = 1: first record of NDEF message
      Bit 6 = ME = 1: last record of NDEF message
      Bit 5 = CF = 0: last or only record of chain
      Bit 4 = SR = 1: short record length field
      Bit 3 = IL = 0: no ID/ID length fields
      Bit 2..0 = 011 = 0x3: Absolute URI Record type
01    Type Length = 1 byte
0E    Payload length = 14 bytes
55    Type field "U" (in US-ASCII) = for URI record
02656E02676F6F676C652E636F6D    Payload field (decoded according to the value of the Type field)- 14 Bytes

02    Status byte
      Bit 7 = 0: Text is UTF-8 encoded
      Bit 6 = 0: Not used
      Bit 5..0 = 0x02: Length of IANA language code field
656E  IANA language code field
      "en" (in US-ASCII) = Text is in English
02676F6F676C652E636F6D URL 0x02 = https://www. (URI identifier code) + 676F6F676C652E636F6D = google.com
      "https://www.google.com" (in UTF-8)

您需要删除您的 'language code field' 和您调用 'status byte' 的字节。

记录类型(55h - 您称为类型字段)之后的第一个字节应该是 URI 标识符(02h,它定义了'https://www.')。然后是你的 URI。

检查您的新负载长度,我已经快速计算出它是 12 个字符 (0Ch)。

您在这里混合了几种不同的记录类型:

  • 绝对URI记录类型,
  • NFC 论坛 well-known 输入 URI,并且
  • NFC 论坛 well-known 输入文本。

您的记录 header 声明该记录为绝对 URI 记录类型 (TNF = 3)。此记录类型使用类型名称字段的 URI(告诉应用程序如何解释记录负载的字段)。因此,在这种情况下,URI 不是实际的记录有效负载,而只是记录内容的描述符。在您的情况下,这样的记录可能如下所示:

+-------------------------+----------------------------------------------------------------
| D3                      | Record header (MB = ME = 1, CF = 0, SR = 1, IL = 0, TNF = 0x3)
+-------------------------+----------------------------------------------------------------
| 16                      | Type Length (22 bytes)
+-------------------------+----------------------------------------------------------------
| 00                      | Payload Length (0 bytes)
+-------------------------+----------------------------------------------------------------
| 68 74 74 70 73 3A 2F 2F | Type Name ("https://www.google.com")
| 77 77 77 2E 67 6F 6F 67 |
| 6C 65 2E 63 6F 6D       |
+-------------------------+----------------------------------------------------------------

虽然 Android 仍会将此记录视为 URI 并应在 Web 浏览器中打开它,但这肯定不是 NDEF 规范的创建者打算使用绝对 URI 记录的目的。

相反,NFC 论坛为此指定了 URI well-known 类型。您已经使用了其中的一部分,因为您的类型名称 ("U") 和有效负载的部分格式与 URI well-known 记录类型匹配。但是,为了声明您的记录是 well-known 类型的记录,您需要将 TNF 字段设置为 1。此外,URI 记录类型的有效负载由一个标识符字节(缩写的 URI 前缀)和截断的 URI。

+-------------------------+----------------------------------------------------------------
| D1                      | Record header (MB = ME = 1, CF = 0, SR = 1, IL = 0, TNF = 0x1)
+-------------------------+----------------------------------------------------------------
| 01                      | Type Length (1 byte)
+-------------------------+----------------------------------------------------------------
| 0B                      | Payload Length (11 bytes)
+-------------------------+----------------------------------------------------------------
| 55                      | Type Name ("U")
+-------------------------+----------------------------------------------------------------
| 02 67 6F 6F 67 6C 65 2E | Payload: Identifier code = 2 (prefix "https://www."),
| 63 6F 6D                |          truncated URI = "google.com"
+-------------------------+----------------------------------------------------------------