开展电子邮件营销活动时,最大的挑战之一是确保您的邮件到达收件箱而不是垃圾邮件文件夹。
apache spamassassin 是许多电子邮件客户端和电子邮件过滤工具广泛使用的工具,用于将邮件分类为垃圾邮件。在这篇文章中,我们将探讨如何利用 spamassassin 来验证您的电子邮件是否会被标记为垃圾邮件以及为什么会被标记为垃圾邮件。
逻辑将被打包为 api 并在线部署,以便可以集成到您的工作流程中。
为什么选择 apache spamassassin?
apache spamassassin 是一个由 apache 软件基金会维护的开源垃圾邮件检测平台。它使用多种规则、贝叶斯过滤和网络测试来为给定的电子邮件分配垃圾邮件“分数”。一般来说,得分为 5 或以上的电子邮件被标记为垃圾邮件的风险很高。
由于 spamassassin 的评分是透明且有据可查的,因此您还可以使用它来准确识别电子邮件的哪些方面导致了高垃圾邮件分数并提高您的写作水平。
spamassassin 入门
spamassassin 设计为在 linux 系统上运行。您需要 linux 操作系统或创建 docker 虚拟机来安装和运行它。
在 debian 或 ubuntu 系统上,使用以下命令安装 spamassassin:
apt-get update && apt-get install -y spamassassinsa-update
sa-update 命令确保 spamassassin 的规则是最新的。
安装后,您可以将电子邮件消息通过管道传输到 spamassassin 的命令行工具中。输出包括带有垃圾邮件分数的电子邮件的带注释版本,并解释了触发哪些规则。
典型用法可能如下所示:
187755762573
results.txt 将包含已处理的电子邮件以及 spamassassin 的标头和分数。
使用 fastapi 将 spamassassin 包装为 api
接下来,让我们创建一个简单的 api,它接受两个电子邮件字段:主题和 html_body。它将把字段传递给 spamassassin 并返回验证结果。
fastapi 代码示例
from fastapi import fastapifrom datetime import datetime, timezonefrom email.utils import format_datetimefrom pydantic import basemodelimport subprocessimport redef extract_analysis_details(text): rules_section = re.search(r"content analysis details:.*?(pts rule name.*?description.*?)nn", text, re.dotall) if not rules_section: return [] rules_text = rules_section.group(1) pattern = r"^s*([-d.]+)s+(s+)s+(.+)$" rules = [] for line in rules_text.splitlines()[1:]: match = re.match(pattern, line) if match: score, rule, description = match.groups() rules.append({ "rule": rule, "score": float(score), "description": description.strip() }) return rulesapp = fastapi()class email(basemodel): subject: str html_body: str@app.post("/spam_check")def spam_check(email: email): # assemble the full email message = f"""from: example@example.comto: recipient@example.comsubject: {email.subject}date: {format_datetime(datetime.now(timezone.utc))}content-type: text/html; charset="utf-8"{email.html_body}""" # run spamassassin and capture the output directly output = subprocess.run(["spamassassin", "-t"], input=message.encode('utf-8'), capture_output=true) output_str = output.stdout.decode('utf-8', errors='replace') details = extract_analysis_details(output_str) return {"result": details}
回复将包含 spamassassin 结果的分析详细信息。
让我们以此输入为例:
subject:test emailhtml_body:this is an html test email.
响应将是这样的:
[ { "rule": "MISSING_MID", "score": 0.1, "description": "Missing Message-Id: header" }, { "rule": "NO_RECEIVED", "score": -0.0, "description": "Informational: message has no Received headers" }, { "rule": "NO_RELAYS", "score": -0.0, "description": "Informational: message was not relayed via SMTP" }, { "rule": "HTML_MESSAGE", "score": 0.0, "description": "BODY: HTML included in message" }, { "rule": "MIME_HTML_ONLY", "score": 0.1, "description": "BODY: Message only has text/html MIME parts" }, { "rule": "MIME_HEADER_CTYPE_ONLY", "score": 0.1, "description": "'Content-Type' found without required MIME headers" }]
在线部署api
运行spamassassin需要安装了该软件的linux环境。传统上,您可能需要 ec2 实例或 digitalocean droplet 来部署,这可能既昂贵又乏味,尤其是在您的使用量较低的情况下。
对于无服务器平台,它们通常不提供像 spamassassin 这样的直接方式来运行系统包。
现在使用 leapcell,您可以部署像 spamassassin 这样的任何系统包,同时保持服务无服务器 – 您只需为调用付费,这通常更便宜。
在 leapcell 上部署 api 非常简单。您不必担心如何设置 linux 环境或如何构建 dockerfile。只需选择要部署的python镜像,并正确填写“build command”字段即可。

部署后,您将拥有一个可以按需调用的端点。每当您的 api 被调用时,它都会运行 spamassassin,对电子邮件进行评分,并返回响应。
以上就是构建 API 让您的营销电子邮件远离垃圾邮件的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1354898.html
微信扫一扫
支付宝扫一扫