从头开始hand-writing DNS消息时,我可以使用以下 pseudo 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];
}
电线断开了。但是,当TXT或SPF字符串的字符数超过255个时,我迷路了,需要帮助!
|###[ 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个。寻找有关如何写入长记录(多个字符串)的指针,以便我可以通过基础套接字将其发送出去。谢谢!
答案 0 :(得分:1)
您不能返回长度超过255个字节的文本片段,而这是DNS格式所不允许的。
SPF允许将记录拆分为多个片段。根据{{3}},您可以在任意位置分割字符串,因为片段边界在语法上并不重要,大多数人会在子句之间进行分割,但没有必要这样做。
返回多个文本片段时,只需像域名处理一样将它们连接起来。 RFC对剪切削减了“ v = spf1”签名的分割保持沉默,因此将第一段的长度不少于7个字节。
[length1字节]“ length1的字符串” [length2字节]“ length2的字符串”
即使总长度小于255,也可以使用多个片段。
在计算rdlen
时一定要包括长度字节