我在 CentOS 5 服务器上运行了 SendMail 8.14.4。
日本的一个用户正在发送一条消息,当它被服务器处理时,SendMail 出于某种原因添加了一个额外的回车符。
该电子邮件包含一个 X 标头,其值(可能)包含国际字符。我说“大概”是因为当我使用 notepad++ 检查 MIME 源时,我看到了类似STX
和CAN
.
我已经能够将测试范围缩小到这个:
如果我通过 Sendmail 发送它,它最终会像这样离开 SendMail:
(更改了 ips、Q-ID 和主机名以保护无辜者)
现在显然这里有一个潜在的危险信号:标题值以引号开头,但没有结束语。这是 RFC 标准所要求的吗?还是那部分是红鲱鱼?
最终结果是标头值泄漏到消息正文中:
关于为什么 sendmail 添加额外的回车的任何想法?
这实际上非常简单:RFC 2822 第 2.2.3 节允许使用长标题,其中标题是字段名,后跟 a:以折叠并在下一行继续,只要(简化)下一行以空格开头
。
原始输入的第 3 行不是以空格开头,而是以字符开头,c并且不包含冒号:,这使得它既不是前一个标题的延续,也不是下一个标题字段(第 2.2 节)。
这标志着它作为标题的结尾......
和身体的开始。
Sendmail 会“纠正”该格式错误的消息,并在它认为的标题结尾和正文开头之间添加所需的空白行。
一个简单的 telnet 邮件会话可以重现该行为:
这会导致与您的示例类似的消息:
在原始标题延续和正文的“新”开始之间增加了一条新线。