AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 706633
Accepted
Mike B
Mike B
Asked: 2015-07-18 09:50:39 +0800 CST2015-07-18 09:50:39 +0800 CST 2015-07-18 09:50:39 +0800 CST

为什么 sendmail 在标题中添加额外的回车?

  • 772

我在 CentOS 5 服务器上运行了 SendMail 8.14.4。

日本的一个用户正在发送一条消息,当它被服务器处理时,SendMail 出于某种原因添加了一个额外的回车符。

该电子邮件包含一个 X 标头,其值(可能)包含国际字符。我说“大概”是因为当我使用 notepad++ 检查 MIME 源时,我看到了类似STX和CAN.

我已经能够将测试范围缩小到这个:

在此处输入图像描述

如果我通过 Sendmail 发送它,它最终会像这样离开 SendMail:

在此处输入图像描述 (更改了 ips、Q-ID 和主机名以保护无辜者)

现在显然这里有一个潜在的危险信号:标题值以引号开头,但没有结束语。这是 RFC 标准所要求的吗?还是那部分是红鲱鱼?

最终结果是标头值泄漏到消息正文中:

在此处输入图像描述

关于为什么 sendmail 添加额外的回车的任何想法?

email-server
  • 1 1 个回答
  • 3349 Views

1 个回答

  • Voted
  1. Best Answer
    HBruijn
    2015-07-18T10:18:38+08:002015-07-18T10:18:38+08:00

    这实际上非常简单:RFC 2822 第 2.2.3 节允许使用长标题,其中标题是字段名,后跟 a:以折叠并在下一行继续,只要(简化)下一行以空格开头。

    一般规则是,只要该标准允许折叠空格(不仅仅是 WSP 字符),就可以在任何 WSP 之前插入 CRLF。例如,头域:
    Subject: This is a test
    可以表示为:

    Subject: This  
     is a test
    

    原始输入的第 3 行不是以空格开头,而是以字符开头,c并且不包含冒号:,这使得它既不是前一个标题的延续,也不是下一个标题字段(第 2.2 节)。

    这标志着它作为标题的结尾......

    和身体的开始。

    Sendmail 会“纠正”该格式错误的消息,并在它认为的标题结尾和正文开头之间添加所需的空白行。

    一个简单的 telnet 邮件会话可以重现该行为:

    [user@example ~]$ telnet localhost 25
    Trying 127.0.0.1...
    Connected to localhost.
    Escape character is '^]'.
    
    <<< 220 example.com ESMTP Sendmail 8.14.4/8.14.4; Fri, 17 Jul 2015 20:29:26 +0200
    
    helo localhost
    
    <<< 250 example.com Hello localhost [127.0.0.1], pleased to meet you
    
    mail from:me@localhost
    
    <<< 250 2.1.0 me@localhost... Sender ok
    
    RCPT TO:[email protected]
    
    <<< 250 2.1.5 [email protected]... Recipient ok
    
    data
    
    <<< 354 Enter mail, end with "." on a line by itself
    
    Subject: test
    X-header: do not try
    this at home
    
    start the body
    .
    <<< 250 2.0.0 t6HITQXA020072 Message accepted for delivery
    quit
    

    这会导致与您的示例类似的消息:

    [user@example ~/Maildir/new]$ cat 1437157845.20091_2.example.com
    
    Return-Path: <[email protected]>
    X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on example.com
    X-Spam-Level:
    X-Spam-Status: No, score=-1.9 required=5.0 tests=ALL_TRUSTED,BAYES_00,
            MISSING_HEADERS autolearn=no version=3.3.1
    Received: from localhost (localhost [127.0.0.1])
            by example.com (8.14.4/8.14.4) with SMTP id t6HITQXA020072
            for [email protected]; Fri, 17 Jul 2015 20:30:06 +0200
    Date: Fri, 17 Jul 2015 20:29:26 +0200
    From: [email protected]
    Message-Id: <[email protected]>
    Subject: test
    X-header: do not try
    
    this at home
    
    start the body
    

    在原始标题延续和正文的“新”开始之间增加了一条新线。

    • 8

相关问题

  • 寻找开源电子邮件归档应用程序 [关闭]

  • 防止您看起来像垃圾邮件发送者的最佳做法 [重复]

  • 什么是允许POP邮箱用户打开和关闭Vaction AutoReply的快速且易于理解的PROCMAIL方式

  • 邮件服务器设置

  • 电子邮件标题包含在电子邮件正文中

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve