构建 API 让您的营销电子邮件远离垃圾邮件

开展电子邮件营销活动时,最大的挑战之一是确保您的邮件到达收件箱而不是垃圾邮件文件夹。

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 的命令行工具中。输出包括带有垃圾邮件分数的电子邮件的带注释版本,并解释了触发哪些规则。

典型用法可能如下所示:

18775576​​2573

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 让您的营销电子邮件远离垃圾邮件

部署后,您将拥有一个可以按需调用的端点。每当您的 api 被调用时,它都会运行 spamassassin,对电子邮件进行评分,并返回响应。

以上就是构建 API 让您的营销电子邮件远离垃圾邮件的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1354898.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 18:52:24
下一篇 2025年12月13日 18:52:41

相关推荐

  • Python Day-String 使用循环、递归、任务的函数逻辑

    1) 在字符串之间添加空格 txt = “todayisfriday”#today is fridayfirst = truefor letter in txt: if letter>=’a’ and letter<='z': if first==true: firs…

    2025年12月13日
    000
  • PyTorch 中的斯坦福汽车

    请我喝杯咖啡☕ *我的帖子解释了斯坦福汽车。 stanfordcars()可以使用stanford cars数据集,如下所示: *备忘录: 第一个参数是 root(必需类型:str 或 pathlib.path)。 *绝对或相对路径都是可能的。第二个参数是 split(可选-默认:”tr…

    2025年12月13日
    000
  • AISuite:简化跨多个 LLM 提供商的 GenAI 集成

    生成式人工智能 (gen ai) 正在凭借其创造力、解决问题和自动化的潜力重塑行业。然而,由于 api 和配置分散,开发人员在集成来自不同提供商的大型语言模型 (llm) 时经常面临重大挑战。互操作性的缺乏使工作流程变得复杂,延长了开发时间,并阻碍了有效的 gen ai 应用程序的创建。 为了解决这…

    2025年12月13日
    000
  • 关于法学硕士 Observability 和 LangSmith 您需要了解的一切

    在人工智能驱动的应用时代,大型语言模型(LLM)已成为解决复杂问题的需求,从生成自然语言到辅助决策过程。然而,这些模型日益复杂和不可预测,使得有效监控和理解其行为变得具有挑战性。这就是可观察性在 LLM 申请中变得至关重要的地方。 可观察性是通过分析系统的输出和指标来理解系统内部状态的实践。对于 L…

    2025年12月13日
    000
  • 代码日的到来仓库困境

    第 15 天:仓库困境 这个谜题并不太难,我发现自己只是做了很多函数以及很多 if 语句和循环。 今天我对 2D 网格导航有点厌倦了,因此很晚才发布这篇文章(我不得不休息一天)。 您一如既往地可以在这里找到我的解决方案。 再说一次,今天没什么值得讨论的重大问题。主要概念是: a) 在网格中循环导航指…

    2025年12月13日
    000
  • 灵感墨水

    标题:利用 InspireInk 释放您的创造力:您的人工智能写作伴侣 写作有时感觉像是一次孤独的旅程,但如果你有一个同伴来引导你度过情节曲折、人物弧线和风格灵感呢?隆重推出 InspireInk,这是一款功能强大的人工智能驱动工具,专为想要提升手艺并将故事变为现实的作家而设计。 什么是 Inspi…

    2025年12月13日
    000
  • 用主轴打造 AP CSP 的未来

    像专业人士一样使用主轴练习 AP® CSP 概念! (诚​​征开发人员)您是一名开发人员,正在寻找一种方式回馈编码社区并帮助未来的计算机科学家吗? Spindle 就是您的最佳选择! Spindle 是一个独特的开源项目,允许学生使用考试中使用的真实实时代码来练习 AP® CSP 考试概念。与传统学…

    2025年12月13日
    000
  • 从多种逻辑到一种高效逻辑

    大家好!今天我想分享一下我的 LeetCode 解题经验。我是数据结构和算法的初学者,目前主要关注Python。我在 LeetCode 上解决了链表概念中的三个问题:合并 k 排序列表、反向链表和两个数字相加。 对于 Merge k Sorted Lists 问题,有多种方法可供选择。但是,选择最有…

    2025年12月13日
    000
  • Jupyter Notebooks 就像电子表格一样学习两者

    电子表格是“商业软件的暗物质”:它们无处不在,它们是隐形的,并且它们将所有东西结合在一起。商业和财务在电子表格上运行;没有其他软件工具能够让这么多人为这么多不同的问题构建解决方案。在这种情况下,您必须将“Jupyter 是新 Excel”的任何断言理解为故意耸人听闻。 但是,Jupyter 笔记本确…

    2025年12月13日
    000
  • PyTorch 中的 CIFAR

    请我喝杯咖啡☕ *我的帖子解释了 cifar-10。 cifar10()可以使用cifar-10数据集,如下所示: *备忘录: 第一个参数是 root(必需类型:str 或 pathlib.path)。 *绝对或相对路径都是可能的。第二个参数是 train(optional-default:true…

    2025年12月13日
    000
  • 如何批量删除Reddit评论(4)

    2024年如何批量删除Reddit评论 编辑(总体最佳)Reddit 的强力删除套件Nuke Reddit 历史 1. Redact(非技术用户批量删除 Reddit 评论的最佳方法) 经验:Redact 提供了一种简单的解决方案,可以批量删除 Reddit 评论和帖子。它提供了对时间范围的精细控制…

    2025年12月13日
    000
  • 使用 Python 自动化数据分析:我的项目实践指南

    数据分析对于各个行业都至关重要,但有效处理原始数据可能是一项艰巨的挑战。通过这个项目,我创建了一个自动化数据分析管道,它简化了数据处理和转换,使其速度更快。 为什么要进行自动化数据分析? 手动流程既耗时又容易出错。为了解决这个问题,我开发了一个基于 Python 的管道,可以自动执行这些任务,同时确…

    2025年12月13日 好文分享
    000
  • 如何使用 Python 和 Boto3 检索 ECnstances 信息

    如果您使用 aws(amazon web services),您可能需要定期与 ec2(弹性计算云)实例进行交互。无论您是管理大量虚拟机还是自动化某些基础设施任务,以编程方式检索 ec2 实例详细信息都可以为您节省大量时间。 在本文中,我们将介绍如何使用 python 和 boto3 sdk 来检索…

    2025年12月13日
    000
  • 使用 Python 和 Boto3 查找并验证 AWS 中未使用的安全组

    有效管理 aws 安全组对于维护安全且经济高效的云环境至关重要。安全组是 aws 网络安全的重要组成部分,但随着时间的推移,未使用的安全组会不断累积。这些未使用的组不仅会使您的环境变得混乱,还可能带来安全风险或不必要地增加成本。 在本文中,我们将探讨如何使用 python 和 boto3 识别 aw…

    2025年12月13日
    000
  • 我们制作了一个 AI SWE,解决了 SWE 工作台上的问题,% 开源

    我们 composio 正在为 ai 代理构建工具基础设施。我们用户最大的要求之一是用于构建有效的自定义编码代理的工具包。因此,我们创建了 swe-kit,这是一个入门模板,其中包含用于构建 ai 编码代理的所有工具包。 这些代理可以在本地端到端运行,以自动化您的编码工作流程。 为了测试我们工具的效…

    2025年12月13日
    000
  • 值得关注的顶级编程语言哪些将塑造未来?

    随着 2025 年的临近,技术格局继续快速发展,推动了对迎合人工智能、云计算、Web 开发等新兴趋势的编程语言的需求。对于希望未来蓬勃发展的开发商和企业来说,保持领先地位至关重要。本文探讨了 2025 年将占据主导地位的 5 种编程语言、它们的主要功能以及它们在塑造未来技术方面的相关性。 1. Py…

    2025年12月13日
    000
  • 探索 Python 的 itertools 模块:释放迭代器的力量

    在 python 编程领域,迭代器在促进数据结构的高效且内存友好的迭代方面发挥着至关重要的作用。 python 中的 itertools 模块是一个功能强大的工具包,它提供了大量用于创建和操作迭代器的函数。在本文中,我们将深入研究 python 的 itertools 模块,以释放其全部潜力并了解它…

    2025年12月13日 好文分享
    000
  • 代码的出现 &#- 天爪装置

    第 13 天:爪子装置(数学,数学,还有更多数学)。 解决方案链接 今天的挑战是用 python 完成的,但有所改变。做出此选择是为了:a) 测试我的 python / 了解更多 pythonb) 今天看起来像是一个非常沉重的数学难题,所以觉得 python 会是完美的,我没有错 – 它…

    2025年12月13日
    000
  • 强大的 Python 性能优化技术,可实现更快的代码

    作为一名 python 开发人员,我了解到优化代码对于创建高性能应用程序至关重要。在本文中,我将分享我用来增强 python 代码性能的七种强大技术,重点介绍提高执行速度和内存效率的实用方法。 生成器和迭代器 优化 python 代码最有效的方法之一是使用生成器和迭代器。这些工具在处理大型数据集时特…

    2025年12月13日
    000
  • Python 数据分析简介:部分数据类型和变量

    数据类型 数据类型是指定变量可以保存的值/数据类型的分类。 它们包括: integer 或 int:整数(例如 1、43、78、100、34)。 string 或 str:用引号引起来的文本数据。根据编程语言的不同,它们可以用单引号 (”) 或双引号 (“”) 括…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信