`

避免我们的邮件服务器发出的邮件被当成垃圾邮件

阅读更多

转至:

http://hi.baidu.com/dongfangmn/blog/item/a214ec013b554d037aec2c12.html

 

 

 

(经过两天的努力,终于搞好了SPF和DKIM。高兴之余也要记录下来才行)
(DKIM是什么呢?根据DKIM的官方(http://www.dkim.org)说法,是“DomainKeys Identified Mail”,也就是被域名验证过的邮件。)
由于网络上太多垃圾邮件,其中大部分垃圾邮件都冒充其他的域名给我们发送邮件。那么我们怎么知道这个邮件真的是从邮件所声明的域发来的呢?比如,我可以设置一个SMTP服务器,设置邮件域名为gmail.com,那么我就可以自己添加一个帐号是webmaster@gmail.com来发邮件了。

大家觉得听起来还挺可怕的。那么怎么可以避免这些不是从真正的gmail.com服务器发来的垃圾邮件呢?有人说可以通过邮件头查看发送源。对,但我们不可能每一封邮件都查看它的邮件头吧?我们要的是接收邮件服务器可以过滤掉这些垃圾邮件。

我总结了一下常见的做法:

一、通过在DNS里面设置SPF记录,向Internet声明从我们自己的域名发出的邮件会通过哪些服务器来发送。这方法很简单,只要我们的DNS供应商提供的管理界面中可以添加SPF记录就可以设置了(不是所有的供应商会提供这设置,我的域名是在godaddy.com上注册的,可以设置SPF记录)。设置时,添加一个SPF记录,然后输入域名,如果是本域,可用@来表示。然后在VALUE中输入如“v=spf1 ip4:67.202.107.106 -all”的值。 这值分三部分:

(1)v=spf1 说明是一个SPF的v1记录

(2)ip4:67.202.107.106 说明邮件会从此声明IPv4地址发出。它可以是一个IP,或一个IP段。如果有多个IP或多个IP段的话,可以声明多个ip4记录(如“ip4:1.0.1.0/24 ip4:1.0.2.0/24″),每个ip4记录间用空格分隔。另外,除了用IPv4外,还可以有如下选择:

1) ip6: 使用 IPv6 进行验证。
2) a: 使用一个域名进行验证。这将引起对域名服务器进行一次 A RR 查询。可以按照 a:domain, a:domain/cidr 或 a/cidr 的形式来使用。
3) mx: 使用 DNS MX RR 进行验证。MX RR 定义了收信的 MTA,这可能和发信的 MTA 是不同的,这种情况基于 mx 的测试将会失败。 可以用 mx:domain, mx:domain/cidr 或 mx/cidr 这些形式进行 mx 验证。
4) ptr: 使用域名服务器的 PTR RR 进行验证。这时,SPF 使用 PTR RR 和反向图进行查询。如果返回的主机名位于同一个域名之内,就验证通过了。这个参数的写法是 ptr:domain
5) exist: 验证域名的存在性。可以写成 exist:domain 的形式。
6) ext: 定义对 type 的可选扩展。如果没有这个字段,那么仅使用单个记录进行问询。
7) mod: 这是最后的类型指示,作为记录的一个修正值。修正值 描述:
  redirect 重定向查询,使用给出的域名的 SPF 记录。
  以 redirect=domain 的方式使用。
  exp 这条记录必须是最后一条,允许给出一条定制的失败消息。
  IN TXT “v=spf1 mx -all exp=getlost.example.com”
  getlost IN TXT “You are not authorized to send mail for the domain”
(3)-all 定义匹配时的返回值,可有如下选择:

1) + 缺省值。在测试完成的时候表示通过。
2) – 表示测试失败。这个值通常是 -all,表示没有其他任何匹配发生。
3) ~ 表示软失败,通常表示测试没有完成。
4) ? 表示不置可否。这个值也通常在测试没有完成的时候使用。

所以总结如上资料,“v=spf1 ip4:67.202.107.106 -all”的意思是这个域只有67.202.107.106这个IP可以发邮件出来,其他IP的都是非法的。(以上内容参考自:http://baike.baidu.com/view/1372988.htm

二、通过Domainkeys或DKIM给自己的邮件添加一个数字验证。Domainkeys是有Yahoo!提出一个标准,但由于不是完成开源,所以被崇尚开源的DKIM所替代。Domainkeys和DKIM的工作原理都是一样的,就是在邮件服务器上生成一个数字证书,把此数字证书的公钥添加到DNS的txt记录中。然后在邮件服务器上对每封发出的邮件的邮件头中的基本信息(如发件人,收件人,主题等)通过此数字证书的密钥进行加密,把加密后的内容添加到邮件头中。当支持Domainkeys或DKIM的接收邮件服务器(如gmail.com)收到此邮件后,就会通过DNS查询得到发送域中的公钥信息,通过此公钥解密邮件头的相关加密内容,然后再与对应的基本信息比较,看是否匹配。如果发现邮件不匹配的话,就可以认为这邮件被篡改或伪造的了。

我在我的邮件服务器上设置了DKIM,因此用DKIM来说明一下安装的方法:

(可参考http://eric.lubow.org/2009/mail/setting-up-dkim-and-postfix/

(1)下载DKIM的source包,编译安装。由于DKIM需要libmilter模块,如果你用的SMTP软件是sendmail的话,会在sendmail中自带此模块。但如果你用的是其他软件(如postfix)的话,那么就要先下载最新的sendmail source包,解压后可找到子目录“libmilter”。在里面用./Build和./Build install安装libmilter模块。

(2)通过dkim-genkey生成证书。dkim可以给多个服务器发布不同的证书验证。方法是通过Selector来区分。在使用dkim-genkey生成证书时,可通过参数-s来设置selector。如果不指定selector的话,系统默认使用default作为selector。参数-d是域名。

如: dkim-genkey -s mail1 -d jackyhe.com 可生成一个selector是mail1的jackyhe.com下的证书。

名称成功执行后,会在当前目录生成两个名字叫mail1.txt和mail1.private的文件。mail1.txt是公钥部分,需要添加到DNS的txt记录中。

内容如:

mail1._domainkey IN TXT “v=DKIM1; g=*; k=rsa; p=MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC2ubSRHUKzL4ucfzuMKEHyy6rx/WlrZB5SKYKrCsSJWUpQstNqjcaLntaQtmKEnDgDr5rMvklaByf8vE5guqZerZ8UWeBx5joIwuohjkapgM/R6lFmI9VUj8N/c5O9AxQAOQLgnDNPl5OQamUuOp9c5W0jLbYd/hrymPYBSKEi0wIDAQAB” ; —– DKIM mail1 for jackyhe.com

我们需要在DNS的管理界面中添加一个新的txt记录。名字写“mail1._domainkey”(txt文件中红色部分,不同的selector就不同了)。值为txt文件中双引号的内容(如蓝色部分)。

然后,把mail1.private(这是密钥)保存在服务器上的安全的目录。如/etc/mail/dkim/keys。

(3)配置DKIM,DKIM的配置文件是dkim-filter.conf。里面有很多默认的设置。我们只要改下面的内容就可以了:

Domain                  jackyhe.com   ## 设置域名
ExternalIgnoreList      /etc/mail/dkim/trusted-hosts ## 设置可信任机器,如127.0.0.1

InternalHosts           /etc/mail/dkim/trusted-hosts

KeyFile                         /etc/mail/dkim/keys/mail1.private ##就是密钥的保存位置

Selector                mail1 ##本机使用的selector的名字,比如mail1

LocalADSP               /etc/mail/dkim/local-adsp-rules ## 可在此文件中添加自己的ADSP规则(ADSP规则在下面说明)

Socket                  local:/var/run/dkim-milter/dkim.sock

(4)启动DKIM,如 /usr/sbin/dkim-filter -x /etc/dkim-filter.conf

(5)在原来的SMTP服务端(如sendmail,postfix)上修改设置。如postfix中可添加如下设置:

smtpd_milters = unix:/var/run/dkim-milter/dkim.sock
non_smtpd_milters = unix:/var/run/dkim-milter/dkim.sock
milter_protocol = 2

重启SMTP服务后看是否可以发邮件。如果在maillog中看到”DKIM-Signature” header added,就应该大功告成了。

试试发邮件给gmail.com的邮箱,然后在gmail中看看这邮件的邮件头,看看有没有找到dkim=pass。如果有就恭喜你了。

(6)最后说说什么是ADSP。在DKIM说明(http://www.dkim.org/specs/draft-ietf-dkim-ssp-04.html)中提到。我们可以有如下设置来限制没有通过DKIM签名而又用我们的域发出的邮件。

我们可以在DNS中添加一个新的TXT记录,名称是“_adsp._domainkey”,值是“dkim=all”。

“dkim=”后可有三个可选值:

unknow: 意思是从这个域发出的邮件可带DKIM证书,也可不带。

all: 意思是从这个域名发出的证书都应该带DKIM证书的。

discardable: 意思是强烈建议接收邮件的对端把没有DKIM证书或DKIM验证失败的邮件丢弃掉。

而之前提到的“LocalADSP”中的设置,就是在自己服务器上设置规定,在接收对方的邮件时不查询DNS的ADSP记录,而是按照自己的要求设置。

如果大家有疑问,可留意一起探讨。

分享到:
评论

相关推荐

    C#使用163的SMTP服务器发送邮件

    需要注意的是,在使用 163 的 SMTP 服务器发送邮件时,我们需要遵守 163 的邮件发送政策,避免被认为是垃圾邮件。如果您需要发送大量邮件,我们建议您申请一个专门的 SMTP 服务器来避免被认为是垃圾邮件。 使用 163...

    全面剖析邮件服务器垃圾邮件防范术

    只有这样,我们才能在享受电子邮件带来的便捷通信的同时,有效避免垃圾邮件的侵扰。对于企业和个人用户而言,理解并实施这些策略将大幅提高电子邮件使用的安全性,保护用户免受垃圾邮件的威胁。

    简单邮件服务器例子

    邮件服务器主要遵循SMTP(Simple Mail Transfer Protocol)协议来发送邮件,而IMAP(Internet Message Access Protocol)或POP3(Post Office Protocol version 3)用于接收邮件。在这个例子中,我们将关注SMTP...

    Java开源邮件服务器james源码

    5. **反垃圾邮件功能**:James包含了一些内置的反垃圾邮件措施,如RBL查询(Real-time Blackhole List)和SPF(Sender Policy Framework)检查,帮助保护服务器免受垃圾邮件的侵扰。 6. **多语言支持**:James支持...

    企业应如何防范邮件服务器被盗用来发送垃圾邮件参照.pdf

    企业邮件服务器的安全是企业信息安全的重要组成部分,尤其在年底垃圾邮件活动频繁的时期,保护邮件服务器不被滥用发送垃圾邮件显得尤为关键。垃圾邮件不仅浪费用户时间,还可能成为企业内部信息泄露的隐患。邮件...

    java基于socket 利用1邮件服务器发送邮件

    Java基于Socket利用163邮件服务器发送邮件是一个常见的编程任务,尤其在自动化通知、系统报警或者用户服务中广泛应用。在这个项目中,我们将深入探讨如何使用Java的JavaMail API和Socket通信来实现这一功能。 首先...

    JavaMail 具备垃圾邮件过滤功能的邮箱

    黑名单中的地址发送的邮件将被自动拦截,而白名单中的地址则被视为可信,即使它们的邮件可能被其他过滤器标记为垃圾邮件,也会被放行。实现这种功能需要在存储用户设置的地方(如数据库或配置文件)维护这两个列表,...

    局域网内部邮件服务器架设指南

    首先,我们需要理解邮件服务器的基本原理和功能,然后选择适合的软件,最后是配置和管理。 一、邮件服务器基础知识 邮件服务器主要负责收发电子邮件,它遵循SMTP(简单邮件传输协议)来发送邮件,而IMAP或POP3协议...

    基于ApacheJames邮件服务器的收发邮件代码及服务

    在本项目中,我们将探讨如何利用Apache James来实现邮件的发送与接收,并通过JavaMail API进行相关的编程操作。 1. **Apache James邮件服务器的安装与配置** - 下载Apache James最新版本的源码或二进制包。 - ...

    邮件服务器Mercury的设置方法

    这样设置后,邮件服务器将允许向外发送邮件,而不是仅限于本地邮件的转发。 3. 接下来,需要配置协议模块。点击“Configuration/Protocolmodules”,取消选择“Mercury B HTTP webserver”和“Mercury IMAP4rev1 ...

    遥志邮件服务器5.46

    8. **spamlist.txt**:可能是垃圾邮件黑名单,包含已知垃圾邮件发送者的地址,邮件服务器会根据这个列表拦截邮件。 9. **mail**:可能是一个文件夹,包含邮件存储和其他相关文件。 "遥志邮件服务器5.46"的使用通常...

    Linux邮件服务器常见错误报告汇总

    Linux邮件服务器是企业内部通信和外部交流的重要工具,然而在使用过程中可能会遇到各种错误报告,影响邮件的正常发送和...同时,保持良好的邮件发送习惯,避免发送垃圾邮件,也有助于防止被收件方服务器列入黑名单。

    WIndows Server2003邮件服务器搭建PPT

    你需要配置SMTP虚拟服务器,包括设置监听端口、允许发送邮件的用户、设置发信规则以及反垃圾邮件策略等。 4. **设置POP3或IMAP4服务**:对于邮件接收,你可以选择安装Windows POP3服务。配置包括设置监听端口、用户...

    C# 邮件服务器测试

    在本程序中,可以设定间隔时间,自动向邮件服务器发送测试邮件。 5. **邮件服务器日志**: 为了分析邮件服务器的性能和稳定性,程序可能会记录每次发送的详细信息到日志文件,如发送时间、状态、错误信息等。C#中...

    纯java开发邮件服务器(SMTP和POP3协议)

    在这个项目中,我们将主要探讨SMTP(简单邮件传输协议)和POP3(邮局协议第三版)这两种核心协议,以及如何在Java环境中实现它们以支持邮件的发送、接收、群发和转发功能。 SMTP是互联网上用于发送邮件的标准协议。...

    树莓派安装postfix邮件服务1

    在本文中,我们将深入探讨如何在树莓派上安装和配置Postfix邮件服务,以及它与Dovecot、Squirrelmail、SpamAssassin和Sieve的结合使用,以建立一个功能齐全的家庭电子邮件服务器。树莓派因其小巧的体积和低功耗,...

    邮件服务器

    邮件服务器是一种用于发送、接收和管理电子邮件的服务器软件,它使得组织或个人能够拥有自己的电子邮件系统,无需依赖公共的电子邮件服务提供商。MagicWinmailServer是一款适用于Windows操作系统的邮件服务器软件,...

    遥志邮件服务器 CMailServer【标准的互联网邮件服务器】 V5.4.5绿色特别版

    2. **SMTP/POP3 协议**:该服务器遵循 SMTP(Simple Mail Transfer Protocol)和 POP3(Post Office Protocol version 3)协议,确保与全球邮件系统兼容,使用户能够发送和接收来自任何地方的电子邮件。 3. **SSL/...

Global site tag (gtag.js) - Google Analytics