2

在从头开始手写DNS 消息时,我可以使用以下 C代码发送最多 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];
}

它熄灭了电线。但是,当涉及到超过 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<>]还是我错过的其他明显的东西?

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

4

1 回答 1

1

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

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

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

[length1-byte] “长度为 1 的字符串” [length2-byte] “长度为 2 的字符串”

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

一定要在计算中包括长度字节rdlen

于 2019-04-29T22:15:00.663 回答