深入理解电子邮件安全:SPF、DKIM 和 DMARC 完全指南

引言

在当今数字时代,电子邮件已经成为我们日常通信中不可或缺的一部分。然而,随之而来的安全问题也日益突出。邮件欺诈、钓鱼攻击和垃圾邮件等威胁不断增加,这促使了多种邮件安全验证机制的出现。本文将深入探讨三个最重要的邮件安全协议:SPF、DKIM和DMARC。

SPF (Sender Policy Framework)

什么是 SPF?

SPF(发件人策略框架)是一种邮件验证机制,用于防止发件人地址被伪造。它允许域名所有者指定哪些邮件服务器被授权发送来自该域名的邮件。

SPF 工作原理

  1. DNS记录发布:域名所有者在DNS中发布SPF记录
  2. 发送验证:当邮件服务器接收到邮件时,会检查发件人IP是否在SPF记录允许范围内
  3. 结果处理:基于验证结果决定是否接受该邮件

SPF 记录示例

example.com. IN TXT "v=spf1 ip4:192.0.2.0/24 ip4:198.51.100.123 a mx ~all"

DKIM (DomainKeys Identified Mail)

什么是 DKIM?

DKIM是一种数字签名技术,用于验证邮件的完整性和来源真实性。它通过加密签名确保邮件在传输过程中未被篡改。

DKIM 工作流程

  1. 签名生成

    • 发送方使用私钥对邮件头部和内容生成签名
    • 签名添加到邮件头的DKIM-Signature字段
  2. 验证过程

    • 接收方获取发送域名的公钥(存储在DNS中)
    • 使用公钥验证签名的有效性

DKIM 配置示例

selector._domainkey.example.com. IN TXT "v=DKIM1; k=rsa; p=MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC..."

DMARC (Domain-based Message Authentication, Reporting & Conformance)

DMARC 的作用

DMARC建立在SPF和DKIM基础上,提供了统一的邮件验证策略框架。它不仅能验证邮件真实性,还能向域名所有者提供详细的验证报告。

DMARC 政策

  1. none:监控模式,不采取任何操作
  2. quarantine:将可疑邮件放入垃圾邮件文件夹
  3. reject:直接拒绝不符合要求的邮件

DMARC 记录示例

_dmarc.example.com. IN TXT "v=DMARC1; p=reject; rua=mailto:dmarc@example.com"

最佳实践建议

1. 完整部署策略

  • 同时实施SPF、DKIM和DMARC
  • 从宽松策略开始,逐步收紧
  • 定期监控验证报告

2. 密钥管理

  • 定期更新DKIM密钥对
  • 使用足够长度的密钥(建议2048位)
  • 安全保管私钥

3. 监控和维护

  • 定期检查SPF记录是否需要更新
  • 分析DMARC报告发现潜在问题
  • 及时响应验证失败警报

4. 政策调整

  • 根据业务需求调整验证策略
  • 考虑第三方邮件服务的影响
  • 平衡安全性和可用性

结论

电子邮件安全是一个持续演进的领域。SPF、DKIM和DMARC这三个协议互相配合,共同构建了强大的邮件安全防线。正确实施这些机制不仅能有效防止邮件欺诈,还能提升邮件送达率,保护企业声誉。随着网络威胁的不断发展,持续关注和更新邮件安全措施变得越来越重要。

配置
我来详细介绍如何配置 SPF 和 DKIM 的域名解析记录:

  1. SPF 配置步骤:
  1. 登录域名管理控制台,添加 TXT 记录:
  • 主机记录:@ 或者留空(取决于服务商)
  • 记录类型:TXT
  • 记录值示例:
v=spf1 ip4:1.2.3.4 ip4:11.22.33.44 include:spf.example.com include:_spf.google.com ~all
  1. SPF 记录值说明:
  • v=spf1 - SPF 版本声明
  • ip4: - 指定 IPv4 地址
  • include: - 包含其他域名的 SPF 记录
  • ~all - 软失败(推荐)或 -all 硬失败
  • +all - 允许所有(不推荐)

常见配置场景:

# 只允许指定 IP 发送
v=spf1 ip4:1.2.3.4 -all# 允许本域名的 MX 记录对应的服务器发送
v=spf1 mx -all# 允许本域名的 A 记录对应的服务器发送
v=spf1 a -all# 包含第三方邮件服务(如 Google Workspace)
v=spf1 include:_spf.google.com -all
  1. DKIM 配置步骤:
  1. 生成 DKIM 密钥对:
# 使用 OpenSSL 生成私钥
openssl genrsa -out private.key 2048# 生成公钥
openssl rsa -in private.key -pubout -out public.key
  1. 添加 DKIM DNS 记录:
  • 主机记录:selector._domainkey (selector 可自定义,如 mail._domainkey)
  • 记录类型:TXT
  • 记录值示例:
v=DKIM1; k=rsa; p=MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA...
  1. DKIM 记录值说明:
  • v=DKIM1 - DKIM 版本
  • k=rsa - 加密算法
  • p= - 公钥(去掉头尾和换行)

常见邮件服务商的 DKIM 配置:

Google Workspace:

# 主机记录
google._domainkey# 记录值
v=DKIM1; k=rsa; p=您的公钥

Microsoft 365:

# 主机记录
selector1._domainkey# 记录值
v=DKIM1; k=rsa; p=您的公钥

验证配置:

  1. SPF 验证:
# 使用 dig 命令查询
dig txt example.com# 使用在线工具
https://mxtoolbox.com/spf.aspx
  1. DKIM 验证:
# 发送测试邮件查看邮件头
# 使用在线工具
https://mxtoolbox.com/dkim.aspx

注意事项:

  1. DNS 传播时间:
  • 新增或修改记录后需等待 DNS 刷新(通常 5-30 分钟)
  • 某些情况可能需要最多 24-48 小时
  1. 记录长度限制:
  • 单条 TXT 记录最大 255 字符
  • 超长需要分片,用引号分隔
  1. 安全建议:
  • 私钥妥善保管,避免泄露
  • 建议每 6-12 个月轮换密钥
  • 先添加新记录,确认生效后再更换密钥
  1. 常见错误:
  • SPF 记录重复
  • DKIM 选择器名称错误
  • 公钥格式不正确
  • DNS 记录未及时生效

查询链接

https://coding.tools/cn/nslookup 
https://powerdmarc.com/zh/spf-record-lookup/
https://powerdmarc.com/zh/dkim-record-lookup/
https://powerdmarc.com/zh/dmarc-record-checker/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/61581.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++:shared_from_this()应用在异步任务中的应用

shared_from_this() 的主要用途是安全地创建 std::shared_ptr 实例来管理当前对象的生命周期&#xff0c;确保对象在异步任务或新线程中不会在使用过程中被销毁。示例如下&#xff1a; 示例代码&#xff1a; #include <iostream> #include <memory> #include <…

vue-quill-editor富文本组件二次封装,上传图片是base64的图片回显异常,进行自定义上传

<template><div><QuillEditor ref"myQuillEditor" theme"snow" :content"modelValue" :options"data.editorOption" contentType"html" update:content"setValue" /><!-- 使用自定义图片上传…

关于一次开源java spring快速开发平台项目RuoYi部署的记录

关于一次开源java spring快速开发平台项目RuoYi部署的记录 本次因为需要一些练习环境&#xff0c;想要快速搭建一个javaweb 项目作为练习环境&#xff0c;经过查询和实验找到一个文档详细&#xff0c;搭建简单&#xff0c;架构也相对比较新的开源项目RuoYi。 项目介绍&#xf…

Quartus+Nios II for eclipse问题合集

由于对于FPGANIOS II 的工作需要&#xff0c;对工作过程中遇到的问题进行记录&#xff0c;持续更新。 1、BSP directory does not exist: . Stop.Nios II使用过程中遇到的一些问题2_error executing nios2-bsp-generate-files --bsp-di-CSDN博客https://blog.csdn.net/qq_39485…

「OpenCV交叉编译」ubuntu to arm64

Ubuntu x86_64 交叉编译OpenCV 为 arm64OpenCV4.5.5、cmake version 3.16.3交叉编译器 gcc-arm-10.2-2020.11-x86_64-aarch64-none-linux-gnu 可在arm或linaro官网下载所需版本&#xff0c;本文的交叉编译器可点击链接跳转下载 Downloads | GNU-A Downloads – Arm Developer L…

Vue通用组件设计原则

在 Vue.js 开发中&#xff0c;设计通用组件是一项重要的任务&#xff0c;可以提升代码的复用性和可维护性。以下是通用组件设计的主要原则和最佳实践&#xff1a; 1. 清晰的职责划分 通用组件应该具有单一的职责&#xff0c;专注于完成某一类特定功能&#xff0c;而不依赖具体…

基于深度学习的点云分割网络及点云分割数据集

点云分割是根据空间、几何和纹理等特征对点云进行划分&#xff0c;使得同一划分内的点云拥有相似的特征。点云的有效分割是许多应用的前提&#xff0c;例如在三维重建领域&#xff0c;需要对场景内的物体首先进行分类处理&#xff0c;然后才能进行后期的识别和重建。 传统的点…

Excel - VLOOKUP函数将指定列替换为字典值

背景&#xff1a;在根据各种复杂的口径导出报表数据时&#xff0c;因为关联的表较多、数据量较大&#xff0c;一行数据往往会存在三个以上的字典数据。 为了保证导出数据的效率&#xff0c;博主选择了导出字典code值后&#xff0c;在Excel中处理匹配字典值。在查询百度之后&am…

硬件知识 cadence16.6 原理图输出为pdf 网络名下划线偏移 (ORCAD)

1. cadence原理图输出为PDF网络名下划线偏移 生这种情况的原因 1. 设计的原理图图纸大小比正常的 A4图纸大。 2. 打印为PDF 的时候&#xff0c;打印机的设置有问题。 2.cadence原理图输出为 PDF网络名下划线偏移的情况 可以看到上图&#xff0c;网络名往上漂移。 3. 解决办法 …

华为机试HJ58 输入n个整数,输出其中最小的k个

首先看一下题 描述 输入n个整数&#xff0c;找出其中最小的k个整数并按升序输出 本题有多组输入样例 数据范围&#xff1a; 1≤n≤1000 &#xff0c;输入的整数满足 1≤val≤10000 输入描述&#xff1a; 第一行输入两个整数n和k 第二行输入一个整数数组 输出描述&#xff1…

【视觉SLAM】4b-特征点法估计相机运动之PnP 3D-2D

文章目录 0. 前言1. PnP求解1.1 直接线性变换DLT1.2 P3P1.3 光束平差法BA2. 实现0. 前言 透视n点(Perspective-n-Point,PnP)问题是计算机视觉领域的经典问题,用于求解3D-2D的点运动。换句话说,当知道 N N N个世界坐标系中3D空间点的坐标以及它们在图像上的投影点像素坐标…

随机森林(Random Forest)详解

✅作者简介&#xff1a;2022年博客新星 第八。热爱国学的Java后端开发者&#xff0c;修心和技术同步精进。 &#x1f34e;个人主页&#xff1a;Java Fans的博客 &#x1f34a;个人信条&#xff1a;不迁怒&#xff0c;不贰过。小知识&#xff0c;大智慧。 &#x1f49e;当前专栏…

对原jar包解压后修改原class文件后重新打包为jar

文章目录 背景三种修改方式1.POM中移除原jar中依赖的历史版本2.原jar它不使用pom依赖而是直接放在源码中再编译使用JarEditor 插件对源码进行修改(推荐)使用java-decompiler反编译后修改源码覆盖原class&#xff08;不好用-不推荐直接跳过&#xff09;提醒 参考资料-推荐阅读拓…

PyQt6+pyqtgraph折线图绘制显示

1、实现效果 2、环境&#xff1a; 确认已经安装pyqtgraph的模块&#xff0c;如果没有安装&#xff0c;使用命令安装&#xff1a; pip install pyqtgraph 3、代码实现&#xff1a; 绘制折线函数&#xff1a; import sys import random from PySide6.QtWidgets import QAppl…

Altium Designer学习笔记 1-5 工程创建_元件库创建

基于Altium Designer 23学习版&#xff0c;四层板智能小车PCB 目录 1、工程组成 2、AD工程创建 3、元件库的阻容模型创建 4、IC类的元件库模型创建 5、排针类的元件库模型创建 1、工程组成 主要包括原理图库----原理图----PCB库----PCB 2、AD工程创建 新建工程项目 …

java SQL中使用for update作用和用法

在 Java 开发中&#xff0c;使用 FOR UPDATE 子句的 SQL 查询主要用于实现行级锁定&#xff0c;以确保在事务处理过程中数据的一致性和完整性。FOR UPDATE 通常在以下情况下使用&#xff1a; 1. 行级锁定 FOR UPDATE 会锁定查询结果集中涉及的行&#xff0c;防止其他事务在同一…

C++:operator new/delete函数

每个类默认都会有一个全局范围的 operator new 和 operator delete 接口&#xff0c;它们是由标准库提供的&#xff0c;可以用于动态内存分配和释放。如果一个类没有显式定义自己的 operator new 或 operator delete&#xff0c;默认的全局版本会被使用。 默认 operator new 的…

Video Duplicate Finder 快速识别并去除重复的视频和图像!

文章目录 下载 后续升级 Video Duplicate Finder&#xff08;视频重复查找器&#xff09;是一款开源的跨平台视频&#xff08;以及图像&#xff09;去重软件&#xff0c;通过对比文件内容和特征&#xff0c;快速识别出重复的视频和图像文件&#xff0c;即使是被压缩裁剪过、…

力扣力扣力:860柠檬水找零

860. 柠檬水找零 - 力扣&#xff08;LeetCode&#xff09; 需要注意的是&#xff0c;我们一开始是没有任何钱的&#xff0c;也就是说我们需要拿着顾客的钱去找零。如果第一位顾客上来就是要找零那么我们无法完成&#xff0c;只能返回false。 分析&#xff1a; 上来我们先不分…

字符串与十六进制表示的字符串相互转换字符串倒序

字符串转为十六进制表示的字符串: /// <summary> /// 此方法用于将普通字符串转换成16进制的字符串。 /// </summary> /// <param name"_str">要转换的字符串。</param> /// <returns></returns&g…