文档介绍:SMTP协议分析及实验—:SMTP简介SMTP(SimpleMailTransferProtocol)即简单邮件传输协议,是一种提供可靠且有效电子邮件传输的协议。SMTP是建立在FTP文件传输服务上的一种邮件服务,主要用于传输系统之间的邮件信息并提供与来信有关的通知。传输E-Mail的标准,是一个相对简单的基于文本的协议。在其之上指定了一条消息的一个或多个接收者(在大多数情况下被确定是存在的),然后消息文本就传输了。程序来测试一个SMTP服务器,SMTP使用TCP端口25。要为一个给定的域名决定一个SMTP服务器,需要使用MX(MaileXchange)DNS。SMTP协议发展在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服务器包括PhilipHazel的exim,IBM的Postfix,,,在二进制文件上处理得并不好。后來开发了用來编码二进制文件的标准,如MTME,以使其通过SMTP来传输。今天,大多数SMTP服务器都支持8位MIME扩展,它使二进制文件的传输变得几乎和纯文本一样简单。(注意:SMTP是一个〃推〃的协议,它不允许根据需要从远程服务器上“拉”来消息。要做到这点,邮件客户端必须使用POP3或IMAP上。另一个,SMTP服务器可以使用ETRN(ExtendedTurn,扩展回车)命令在SMTP上触发一个发送。)垃圾邮件仍然是个重要的问题。原始的SMTP协议的局限之一在于它没有为发送方进行认证的功能。因此定义了SMTP-AUTH扩展。由于SMTP巨大安装基础的网络效应,广阔地修改SMTP或者完全替代它被认为是不现实的。Mail2000就是这样一个为替换而做的建议。TRTF的反垃圾邮件研究小组正在研究一些提供简单、灵活、轻量级的、可升级的源端认证的建议。最有可能被接受的建议是SenderPolicyFramework协议。协议的工作原理用户代理(发送邮件)SMT’鬲屛务W(TCP连接](发送邮件)(TCP连技)(读取邮件)POP3邮件(TCP连授:用户巒(读取邮件)亠\POP3接收方用户代遅发送方(发送邮件)c—SMTP/(发送邮件)SMTP在邮件通信中的位置如下图所示:用户代理/邮件缓存发送端邮件服务器接收端邮件服务器因轻网用户代理1、工作机制:SMTP通常有两种工作模式:发送SMTP和接收SMTPo具体工作方式为:发送SMTP在接到用户的邮件请求后,判断此邮件是否为本地邮件,若是直接投送到用户的邮箱,否则向dns查询远端邮件服务器的MX纪录,并建立与远端接收SMTP之间的一个双向传送通道,此后SMTP命令由发送SMTP发出,由接收SMTP接收,而应答则反方面传送。一旦传送通道建立,SMTP发送者发送MAIL命令指明邮件发送者。如果SMTP接收者可以接收邮件则返回0K应答。SMTP发送者再发出RCPT命令确认邮件是否接收到。如果SMTP接收者接收,则返回0K应答;如果不能接收到,则发出拒绝接收应答(但不中止整个邮件操作),双方将如此重复多次。当接收者收到全部邮件后会接收到特别的序列,如果接收者成功处理了邮件,则返冋0K应答即可。命令和响应都是基于ASCII文本,并以CR和LF符结朿。响应包括一个表示返回状态的三位数字代码。SMTP在TCP协议25号端口监听连续请求。2、连接和发送过程如下:(1) 建立TCP连接。(2) 客户端发送HELO命令以标识发件人自己的身份,然后客户端发送MAIL命令;服务器端正希望以0K作为响应,表明准备接收。(3) 客户端发送RCPT命令,以标识该电子邮件的计划接收人,可以有多个RC