在 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
的计算中包括长度字节
虽然 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