使用 C# 创建 MIME 消息

MIME(多用途互联网邮件扩展)是一种广泛使用的标准,用于格式化和交换电子邮件以及互联网上其他类型的内容。它允许在单个电子邮件中包含各种媒体类型,例如文本、图像、音频和视频。在本文中,我们将探讨如何在 Python 中以编程方式创建 EML 消息。读完本文后,您将清楚地了解如何创建 MIME 消息、将图像添加到电子邮件的 HTML 内容以及将电子邮件保存为 EML 格式。

在 Python 中创建 MIME 消息的 API

要创建 MIME 消息,需要遵守 MIME 标准指定的格式规则。这通常涉及使用编程语言(例如 Python)提供的适当库或模块来生成必要的 MIME 结构。 Aspose.Email for Python 是一个功能强大的库,提供了用于创建、操作和处理电子邮件的广泛功能,使开发人员可以更轻松地将与电子邮件相关的任务合并到他们的 Python 项目中。它旨在支持各种格式和跨不同平台。您可以通过 PyPI下载 其 DLL 轻松安装 API。

> pip install Aspose.Email-for-Python-via-NET

从头开始创建 EML 文件

要创建新电子邮件,我们将使用 Aspose.Email 中的 MailMessage 类。该类具有指定发件人、收件人、主题和 HTML 正文所需的所有方法和属性。然后,该消息将保存为名为“message.eml”的 EML 文件。

创建新的 eml 文件的过程可以按以下步骤描述:

  • 从 aspose.email 模块导入所需的类。
  • 使用默认构造函数创建 MailMessage 类的新实例。
  • 根据需要设置 MailMessage 对象的属性:发件人地址、收件人地址、主题、HTML 正文等。
  • 定义 HTML 结构和内容。在我们的示例中,提供了一个简单的 HTML 结构,其中包含标题和段落。
  • 使用 save 方法将 MailMessage 对象保存到 EML 文件。在我们的示例中,文件的名称为“message.eml”。

下面的代码示例将向您展示如何以编程方式从头开始创建 EML:

from aspose.email import MailMessage, MailAddress, LinkedResource, SaveOptions

# 创建 MailMessage 类的新实例
eml = MailMessage()

# 设置发件人和收件人
eml.from_address = MailAddress("sender@domain.com")
eml.to.append(MailAddress("receiver@receiver.com"))

# 设置主题和正文
eml.subject = "New message with image"
eml.html_body = """<!DOCTYPE html>
 <html>
  <head>
   <style>
    h3{font-family:Verdana, sans-serif;color:#000000;background-color:#ffffff;}
    p {font-family:Verdana, sans-serif;font-size:14px;font-style:normal;
      font-weight:normal;color:#000000;background-color:#ffffff;}
   </style>
  </head>
  <body>
    <h3>New message</h3>
    <p>This is a new message created by Aspose.Email.</p>
  </body>
 </html>"""

#  将 MailMessage 对象保存到 EML 文件
eml.save("message.eml", SaveOptions.default_eml)

MailMessage 类的 save 方法采用两个参数:文件路径和保存选项。保存选项指定输出文件的格式。

将图像添加到 HTML 内容

在本节中,我们将使用同一 API 的 LinkedResource 类在电子邮件中嵌入图像。该类表示消息中的嵌入资源。然后,我们将消息保存为名为“messagewithimage.eml”的 EML 文件。

只需按照步骤操作即可。

  • 从 aspose.email 模块导入所需的类。
  • 使用默认构造函数创建 MailMessage 类的新实例。
  • 根据需要设置 MailMessage 对象的属性。
  • HTML 正文包含一个图像标签,其源属性设置为“cid:myImage”。
  • AlternateView 类用于获取包含嵌入图像的消息正文的备用视图。
  • LinkedResource 类用于表示嵌入图像,其内容 ID 设置为“image1”。
  • 最后,备用视图被添加到消息备用视图集合中。

尝试使用以下代码示例将图像添加到 HTML 内容:

from aspose.email import MailMessage, MailAddress, LinkedResource, SaveOptions
from aspose.email.mime import MediaTypeNames

# 创建 MailMessage 类的新实例
eml = MailMessage()

# 设置发件人和收件人
eml.from_address = MailAddress("sender@domain.com")
eml.to.append(MailAddress("receiver@receiver.com"))

# 设置主题和正文
eml.subject = "New message with image"
eml.html_body = """<!DOCTYPE html>
 <html>
  <head>
   <style>
    h3{font-family:Verdana, sans-serif;color:#000000;background-color:#ffffff;}
    p {font-family:Verdana, sans-serif;font-size:14px;font-style:normal;
      font-weight:normal;color:#000000;background-color:#ffffff;}
   </style>
  </head>
  <body>
    <h3>New message</h3>
    <p>This is a new message created by Aspose.Email.</p>
    <img src='cid:myImage' />
  </body>
 </html>"""

# 将图像资源添加到备用视图
for alternate_view in eml.alternate_views:
    if alternate_view.content_type.media_type == "text/html":
        image_resource = LinkedResource("image.png", "image/png")
        image_resource.content_id = "myImage"
        alternate_view.linked_resources.append(image_resource)

# 将 MailMessage 保存为 EML 文件
eml.save("message_with_image.eml", SaveOptions.default_eml)

从 HTML 文件创建 EML 文件

Python 的 Aspose.Email 库提供了一种简单的方法来加载、修改 HTML 文件并将其另存为 EML 文件。如果您想将 HTML 作为电子邮件发送,则此转换过程会很有用。 为此,我们将使用 HtmlLoadOptions 类。该类允许在从 Html 格式加载 MailMessage 时指定其他选项。首先,我们需要有 HTML 内容。在我们的示例中,它将是一个名为“content.html”的文件。

<!DOCTYPE html>
<html>
<head>
	<title>My Email</title>
</head>
<body>
	<h1>Hello,</h1>
	<img src="logo.png" alt="Logo">
	<p>This is my first email created form HTML.</p>
</body>
</html>

另外,您必须提前准备好所有包含 HTML 的图像,并在 HTML 文件中指定它们的正确路径。

现在,我们可以通过设置“content.html”中的 HTML 正文来轻松创建 MailMessage。

  • 从 aspose.email 模块导入所需的类。
  • 创建 HtmlLoadOptions 的实例以指定 HTML 文件对象的加载选项。
  • 在 pathtoresources 属性中设置包含图像路径的字符串。
  • 如果 EML 应包含纯文本的 AlternateView,则将 shouldaddplaintextview 属性设置为 True。
  • 通过加载 HTML 文件并将 HtmlLoadOptions 对象作为参数传递来创建 MailMessage 的新实例。
  • 设置附加消息属性。
  • 最后,使用 save 方法将 MailMessage 对象保存到 EML 文件中。
from aspose.email import HtmlLoadOptions, MailAddress, MailMessage, SaveOptions

htmlloadOptions = HtmlLoadOptions()
htmlloadOptions.path_to_resources = path
htmlloadOptions.should_add_plain_text_view = True
eml = MailMessage.load(path + str(r"content.html"), htmlloadOptions)

#  设置发件人和收件人
eml.from_address = MailAddress("sender@domain.com")
eml.to = MailAddress("recipient@domain.com")

#  设定主题
eml.subject = "New message from HTML"

#  将消息保存为 EML 格式
eml.save("message_from_html.eml", SaveOptions.default_eml)

改进 Outlook 中 HTML 消息的视图的提示

在发送 HTML 电子邮件时,与不同电子邮件客户端的兼容性至关重要。尤其是 Outlook,其渲染引擎与大多数 Web 浏览器不同,这可能会导致格式问题。这里是其中的一些:

  • Outlook 可能不支持 Web 浏览器中常用的某些 HTML 标记和 CSS 属性。背景图像、浮动、边距和填充等元素可能无法按预期呈现。为了克服这个问题,必须利用内联样式、表格或条件注释来在 Outlook 中实现所需的布局和格式。
  • Outlook 可能会在元素之间引入额外的空格或线条,甚至完全删除某些元素,从而破坏您精心设计的设计。为了缓解这种情况,策略性地使用不间断空格、零宽度空格或空表格单元格可以帮助维护预期的结构并防止 Outlook 中不必要的元素操作。
  • Outlook 的呈现引擎可能会更改 HTML 文件的编码或字符集,从而导致出现乱码或错误显示的字符。为了确保正确呈现,请使用元标记在 HTML 中显式指定编码和字符集。这将帮助 Outlook 准确地解释和显示文本,防止出现任何与字符相关的问题。

结论

总而言之,让我们记住本文讨论了哪些问题。您已经学习了如何使用 Aspose.Email 在 Python 中以编程方式创建 MIME 消息。我们带有代码示例的详细分步说明使本教程具有可读性且易于理解。

通过创建 MIME 消息,电子邮件发件人可以确保他们的通信支持广泛的内容类型,并为收件人提供更具吸引力和交互性的体验。

  • 您可以探索有关 Aspose.Email for Python 的更多信息并免费试用。
  • 您还可以在 文档 中查看 Aspose.Email 的更多特性和功能。
  • 欢迎您在我们的论坛上提出问题。

也可以看看