SMTP协议



SMTP 协议简介


SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,是一种提供可靠且有效

电子邮件传输的协议。

SMTP是建立在

FTP文件传输服务上的一种邮件服务,主要用于传输系统之间的邮件信息并提供与来信有关的通知。


SMTP目前已是事实上的在

Internet传输

E-Mail的标准,是一个相对简单的基于文本的协议。在其之上指定了一条消息的一个或多个接收者(在大多数情况下被确定是存在的),然后消息文本就传输了。可以很简单地通过

Telnet程序来测试一个

SMTP服务器,

SMTP使用

TCP端口25。要为一个给定的域名决定一个

SMTP服务器,需要使用

MX(Mail eXchange)DNS


在20世纪80年代早期

SMTP开始被广泛地使用。当时它只是作为

UUCP的补充,

UUCP更适合于处理在间歇连接的机器间传送邮件。相反

SMTP在发送和接收的机器始终都联网的情况下工作得最好。


SMTP独立于特定的传输子系统,且只需要可靠有序的数据流信道支持。

SMTP重要特性之一是其能跨越网络传输邮件,即“

SMTP邮件中继”。通常,一个网络可以由公用因特网上

TCP可相互间访问的主机、防火墙分隔的

TCP/IP网络上

TCP可相互访问的主机,以及其他

LAN/WAN中的主机利用非

TCP传输层协议组成。使用

SMTP,可实现相同网络上处理机之间的邮件传输,也可通过中继器或网关是实现某处理机与其他网络之间的邮件传输。


在这种方式下,邮件的发送可能经过从发送端到接收端路径上的大量中间中继器或网关主机。域名服务系统(

DNS)的邮件交换服务器可以用来识别出传输邮件的下一跳

IP地址。


Sendmail是最早实现

SMTP的邮件传输代理之一。到2001年至少有50个程序将

SMTP

 实现为一个客户端(消息的发送者)或一个服务器(消息的接受者)。一些其他的流行的 SMTP服务器包括

Philip Hazel

 的 exim,IBM

Postfix,D.J.Bernstein

Qmail,以及Mi

crosoft Exchange Server.


由于这个协议开始是基于纯

ASCⅡ文本的,在二进制文件上处理得并不好。后来开发了用来编码二进制文件的标准,如

MIME,以使其通过

SMTP来传输。今天,大多数

SMTP服务器都支持8位

MIME扩展,它使二进制文件的传输变得几乎和纯文本一样简单。


( 注意:

SMTP是一个"推"的协议,它不允许根据需要从远程服务器上“拉”来消息。要做到这点,邮件客户端必须使用

POP3

IMAP上。另一个,

SMTP服务器可以使用

ETRN(

Extended Turn,扩展回车)命令在

SMTP上触发一个发送。)


垃圾邮件仍然是个重要的问题。原始的

SMTP协议的局限之一在于它没有为发送方进行认证的功能。因此定义了

SMTP-AUTH

 扩展。由于 SMTP

 巨大安装基础的网络效应,广阔地修改 SMTP或者完全替代它被认为是不现实的。

Internet Mail

  2000

 就是这样一个为替换而做的建议。 IRTF 

反垃圾邮件研究小组正在研究一些提供简单、灵活、轻量级的、可升级的源端认证的建议。最有可能被接受的建议是

Sender Policy Framework

 协议。

SMTP协议命令和工作原理


SMTP命令是发送于

SMTP主机之间的

ASCⅡ信息,可能使用到的命令如下表所示。


SMTP协议命令


命令

描述

DATA

开始信息写作

EXPN<string>

验证给定的邮箱列表是否存在,扩充邮箱列表,也常被禁用

HELO<domain>

向服务器标识用户身份,返回邮件服务器身份

HELP<command>

查询服务器支持什么命令,返回命令中的信息

MAIL FROM<host>

在主机上初始化一个邮件会话

NOOP

无操作,服务器应响应OK

QUIT

终止邮件会话

RCPT TO<user>

标识单个的邮件接收人;常在MAIL命令后面可有多个rcpt to:

RSET

重置会话,当前传输被取消

SAML FROM<host>

发送邮件到用户终端和邮箱

SEND FROM<host>

发送邮件到用户终端

SOML FROM<host>

发送邮件到用户终端或邮箱

TURN

接收端和发送端交换角色

VRFY<user>

用于验证指定的用户/邮箱是否存在;由于安全方面的原因,服务器常禁止此命令



SMTP是工作在两种情况下:一是电子邮件从客户机传输到服务器:二是从某一个服务器传输到另一个服务器。 SMTP也是个请求/响应协议,命令和响应都是基于 ASCⅡ文本,并以 CRLF符结束。响应包括一个表示返回状态的三位数字代码。 SMTPTCP协议25号端口监听连续请求。
连接和发送过程如下:
(1)建立 TCP  连接。
(2)客户端发送 HELO命令以标识发件人自己的身份,然后客户端发送 MAIL命令;服务器端正希望以 OK作为响应,表明准备接收。
(3)客户端发送 RCPT命令,以标识该电子邮件的计划接收人,可以有多个 RCPT行;服务器端则表示是否愿意为收件人接收邮件。
(4)协商结束,发送邮件,用命令 DATA发送。
(5)以“ .”号表示结束输入内容一起发送出去,结束此次发送,用 QUIT命令退出。
下面介绍一下 SMTP协议的邮件路由过程。
SMTP服务器基于域名服务 DNS中计划收件人的域名来路由电子邮件。 SMTP服务器基于 DNS中的 MX记录来路由电子邮件, MX记录注册了域名和相关的 SMTP中继主机,属于该域的电子邮件都应向该主机发送。若 SMTP服务器 mail.abc.com 收到一封信要发到 shuer@sh.abc.com,则执行以下过程:
(1) Sendmail 请求 DNS给出主机sh.abc.com的 CNAME  记录,如有,假若 CNAME(别名记录)到shmail.abc.com,则再次请求shmail.abc.com的 CNAME记录,直到没有为止。
(2)假定被 CNAME到shmail.abc.com,然后 sendmail请求@abc.com 域的 DNS给出shmail.abc.com的 MX记录(邮件路由及记录),shmail MX 5 shmail.abc.com 10 shmail2.abc.com。
(3) Sendmail组合请求 DNS给出shmail.abc.com的A记录(主机名(或域名)对应的 IP地址记录),即 IP地址,若返回值为1.2.3.4(假设值)。
(4) Sendmail与1.2.3.4连接,传送这封给shuser@sh.abc.com 的信到1.2.3.4 这台服务器的 SMTP后台程序。