4

问题:

我试图复制 yahoo 和 hotmail 使用的基于 SMTP 的标头/电子邮件并通过 Telnet 发送它们,但我收到的电子邮件不显示包含的附件​​,但它确实正确显示了消息。

我怀疑是什么原因造成的:

我相信我的电子邮件格式不正确,尽管在网上搜索了许多文章(以及试图掌握复杂且难以阅读的 RFC),但我没有找到任何有用或简洁的文章来解释如何使用这三种方法(Plain 、HTML 和附件)在 SMTP 中正确。我花了几天时间尝试更改代码,但我要么得到消息(没有附件),要么得到整个 SMTP 数据主体显示(包括边界、html 代码等)。

我希望通过这个问题实现的目标:

我希望有人可以查看我在下面收集的信息,并能够告诉我我遗漏了什么(或者电子邮件的格式究竟有多不正确)。

调试信息:

我将发送到 SMTP 服务器的信息的副本提供给文件,并将信息粘贴到 pastebin(删除/编辑了任何个人信息 - Base64 编码附件只是从 IMAP 获得的另一封电子邮件的文本文件):

将信息逐字(减去控制字符)发送到 SMTP 服务器:

http://pastebin.com/QYwzWT0S

我在电子邮件客户端中看到的内容(注意没有附件):

http://i45.tinypic.com/29b1zci.jpg

下载电子邮件时 IMAP 看到的内容(注意格式不正确):

http://pastebin.com/zv3PBr8N

正确格式的电子邮件在 IMAP 中应该是什么样子:

http://pastebin.com/3yBySbxU

我怀疑 SMTP 误解了我发送的内容,这就是 IMAP 尝试检索电子邮件时缺少 multipart/alternative 的原因。我到底做错了什么?服务器期望什么?

[感谢您的支持-我可以重新启用链接!]

4

2 回答 2

8

我清理了多部分边界说明符并得到了这个,它适用于我的服务器(我在这里省略了 SMTP 命令):

From: "Edited Out" <editedout@yahoo.com> 
To: "Edited Out" <editedout@yahoo.com> 
Subject: Testing 4
MIME-Version: 1.0
Content-Type: multipart/alternative;
  boundary="boundary-type-1234567892-alt"

--boundary-type-1234567892-alt
Content-Type: text/plain; charset="iso-8859-1"
Content-Transfer-Encoding: quoted-printable


Testing the text to see if it works!

--boundary-type-1234567892-alt
Content-Type: text/html; charset="iso-8859-1"
Content-Transfer-Encoding: quoted-printable


<html>Does this actually work?</html>

--boundary-type-1234567892-alt
Content-Transfer-Encoding: base64
Content-Type: text/plain;name="Here2.txt"
Content-Disposition: attachment;filename="Here2.txt"

KiAxMyBGRVRDSCAoQk9EWVtURVhUXSB7NjU5fQ0KLS1fZjZiM2I1ZWUtMjA3YS00ZDdiLTg0NTgtNDY5YmVlNDkxOGRhXw0    KQ29udGVudC1UeXBlOiB0ZXh0L3BsYWluOyBjaGFyc2V0PSJpc28tODg1OS0xIg0KQ29udGVudC1UcmFuc2Zlci1FbmNvZG    luZzogcXVvdGVkLXByaW50YWJsZQ0KDQoNCkp1c3Qgc2VlaW5nIHdoYXQgdGhpcyBhY3R1
YWxseSBjb250YWlucyEgCQkgCSAgIAkJICA9DQoNCi0tX2Y2YjNiNWVlLTIwN2EtNGQ3Yi04NDU4LTQ2OWJlZTQ5MThkYV8    NCkNvbnRlbnQtVHlwZTogdGV4dC9odG1sOyBjaGFyc2V0PSJpc28tODg1OS0xIg0KQ29udGVudC1UcmFuc2Zlci1FbmNvZG    luZzogcXVvdGVkLXByaW50YWJsZQ0KDQo8aHRtbD4NCjxoZWFkPg0KPHN0eWxlPjwhLS0N
Ci5obW1lc3NhZ2UgUA0Kew0KbWFyZ2luOjBweD0zQg0KcGFkZGluZzowcHgNCn0NCmJvZHkuaG1tZXNzYWdlDQp7DQpmb25    0LXNpemU6IDEwcHQ9M0INCmZvbnQtZmFtaWx5OlRhaG9tYQ0KfQ0KLS0+PC9zdHlsZT48L2hlYWQ+DQo8Ym9keSBjbGFzcz    0zRCdobW1lc3NhZ2UnPjxkaXYgZGlyPTNEJ2x0cic+DQpKdXN0IHNlZWluZyB3aGF0IHRo
aXMgYWN0dWFsbHkgY29udGFpbnMhIAkJIAkgICAJCSAgPC9kaXY+PC9ib2R5Pg0KPC9odG1sPj0NCg0KLS1fZjZiM2I1ZWU    tMjA3YS00ZDdiLTg0NTgtNDY5YmVlNDkxOGRhXy0tDQopDQpmbHlubmNvbXB1dGVyIE9LIEZFVENIIGNvbXBsZXRlZA


--boundary-type-1234567890-alt--

多部分电子邮件中的边界说明符是不太可能出现在电子邮件正文/附件中的任意文本。当它在前面出现两个破折号时,表示新部分的开始(包括第一部分。当它在开头和结尾出现两个破折号时,表示邮件的结尾。

您的原始邮件在邮件中间(就在 之后<html>Does this actually work?</html>)有这个“结束边界”标记,并且有两个不同的边界标记(--boundary-type-1234567890--boundary-type-1234567892-alt)。这就解释了为什么附件被遗漏了。

于 2012-06-05T02:57:37.163 回答
3

事实证明,这个问题非常微妙。

Hotmail 传统上(这是我基于它的原始电子邮件),对电子邮件的多个部分使用术语“多部分/替代”。我在电子邮件中使用了“multipart/alternative”。

事实证明,雅虎不喜欢“多部分/替代”,并且只会在使用“多部分/混合”一词时正确显示纯文本、html 和附件(因为我注意到雅虎兼容的电子邮件使用这个词而不是替代词) ,结合 ejdyksen 的建议(尽管这两个建议都不适用于雅虎的服务器)。

虽然从技术上讲,这是“正确”的答案,但我会选择 ejdyksen 的答案,因为他的努力表明这是一些服务器端的技术问题(他的 SMTP 服务器和 hotmail 都显示了附件,而雅虎没有)。礼貌地支持 ejdyksen 的回答,因为他做了大部分的跑腿工作。

于 2012-06-05T14:41:49.610 回答