在 TXT 或 SPF 记录中写入超过 255 个字符的数据

Writing more than 255 characters of data in a TXT or SPF record

虽然 hand-writing 从头开始​​ DNS 消息,但我可以使用此 pseudo C[=27= 发送最多 255 个字符的 TXT 记录]代码:

char use_this[1024];
memset(use_this, 0, 1024); 
use_this[0] = len;
for (int i = 0; i < len; i++){
        use_this[i + 1] = txt_record[i];
}

出线OK。但是,当涉及到超过 255 个字符的 TXT 或 SPF 字符串时,我迷路了,需要帮助!

   |###[ DNS Resource Record ]###
   |  rrname    = 'bbc.com.'
   |  type      = SPF
   |  rclass    = IN
   |  ttl       = 748
   |  rdlen     = 334
   |  rdata     = '\xdav=spf1 ip4:212.58.224.0/19 ip4:132.185.0.0/16 ip4:78.136.53.80/28 ip4:78.136.14.192/27 ip4:78.136.19.8/29 ip4:89.234.10.72/29 ip4:74.112.66.33 ip4:208.251.80.51 ip4:89.202.185.0/24 ip4:207.159.133.98 ip4:207.159.133.99r include:msgfocus.com include:cmail1.com include:mktomail.com include:servers.mcsv.net include:redsnapper.net ?all'
  ns        = None

对于 336 个字符长的字符串,它应该是:[255][chars0:255] + [81][255:][336][chars<>],还是我遗漏的其他明显内容?

我们可以有 TXT / SPF 记录 larger than 255 个字符,但单个字符串中不能超过 255 个字符。寻找有关如何编写(多个字符串的)长记录的指针,以便我可以通过底层套接字将其发送出去。谢谢!

您不能 return 超过 255 字节的文本片段,这是 DNS 格式不允许的。

SPF 允许将记录拆分成片段。根据 https://www.rfc-editor.org/rfc/rfc7208#section-3.3 你可以在任何位置拆分字符串,因为片段边界在语法上不重要,大多数人会在子句之间拆分,但没有要求这样做。

当 return 连接多个文本片段时,只需将它们连接起来,就像处理域名一样。 RFC 对切割签名“v=spf1”的拆分保持沉默,因此请保持第一个段的长度不少于 7 个字节。

[length1-byte] "string of length1" [length2-byte] "string-of-length2"

即使总长度小于 255,也可以使用多个片段。

一定要在rdlen

的计算中包括长度字节