现在的位置: 首页 > 综合 > 正文

SMTP协议分析

2018年05月26日 ⁄ 综合 ⁄ 共 1545字 ⁄ 字号 评论关闭

最近在论坛上的一些朋友问脚本方面的问题,比如用lrwinsock协议录制的脚本遇回放过程中遇到如下错误

Action.c(20): Error : callConnect - Can't assign requestedaddress. Error code : 10049.
Action.c(20): Error : Timeout expired while tryingto connect. Error code : 9017.

这里的10049udp协议错误,是脚本没有和服务器同步,这说明什么问题呢。下边我用一个协议进行分析,来看看到底是什么问题,
smtp
协议分析:

1.SMTP工作方式有两种情况:一是电子邮件从客户机传输到服务器;二是从某一个服务器传输到另一个服务器
2.SMTP
是个请求/响应协议,命令和响应都是基于ASCII文本,并以CRLF符结束。响应包括一个表示返回状态的三位数字代码
3.SMTP
TCP协议25号端口监听连接请求 
4.
连接和发送过程:

a.建立TCP连接 
b.
客户端发送HELO命令以标识发件人自己的身份,然后客户端发送MAIL命令 
服务器端正希望以OK作为响应,表明准备接收 
c.
客户端发送RCPT命令,以标识该电子邮件的计划接收人,可以有多个RCPT 
服务器端则表示是否愿意为收件人接受邮件 
d.
协商结束,发送邮件,用命令DATA发送 
e.
.表示结束输入内容一起发送出去 
f.
结束此次发送,用QUIT命令退出。

5.另外两个命令: 
VRFY---
用于验证给定的用户邮箱是否存在,以及接收关于该用户的详细信息。 
EXPN---
用于扩充邮件列表。

6.邮件路由过程: 
SMTP
服务器基于域名服务DNS中计划收件人的域名来路由电子邮件。SMTP服务器基于DNS中的MX记录来路由电子邮件,MX记录注册了域名和相关的SMTP中继主机,属于该域的电子邮件都应向该主机发送。

SMTP服务器mail.withub.org收到一封信要发到pcl@withub.org

a.Sendmail请求DNS给出主机withub.orgCNAME记录,如有,假若CNAMEmail.withub.org,则再次请求mail.withub.orgCNAME记录,直到没有为止
b.
假定被CNAMEmail.withub.org,然后sendmail请求@withub.org域的DNS给出mail.withub.orgMX记录, 
shmail MX 5 mail.withub.org

10 shmail2.withub.org 
c. Sendmail最后请求DNS给出shmail.withub.orgA记录,即IP地址,若返回值为1.2.3.4 
d. Sendmail
1.2.3.4连接,传送这封给pcl@withub.org的信到1.2.3.4这台服务器的SMTP后台程序

这里是协议的一个解析过程,我们要看看,利用lr录制脚本后然后回放,录制的过程中mail.withub.org返回客户端服务器上有多少给用户的邮件,lr把这个数字保存下来,最为下次回放的时候对比。当你第二次回放的时候,lr模拟客户端发送请求,这时候服务器上没有了新邮件,返回可能是0,lr把这个返回值和当时录制的脚本保存的返回值进行对比(那个时候可能服务器上有3个新的邮件,服务器返回的值是3),明显这个值是动态变化的。你的脚本如果没有经过修改,肯定是回返不成功的。

那么上边提到的错误信息,同样的道理,我们要分析一下到底是什么问题,从协议上分析,从系统环境上分析。

解决方法,动态关联

1.用同样的用户操作同样的步骤两次,然后用lr工具wdiff进行脚本对比,找出不同的地方!

2.lr自动关联

3.手工关联,找到要替换的动态数据进行替换


抱歉!评论已关闭.