ESMTP协议如何进行身份验证

王朝vc·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

ESMTP采取了为了防止垃圾邮件的泛滥,采用了身份验证机制。但是在实际的使用过程中,我有时发现我输入的验证密码是正确的,但是系统提示却是错误的,这是什么原因呢?

下面分析ESMTP 的身份验证机制:

(连接到smtp.elong.com:25)

220 sp1 ESMTP v2.1

EHLO ABCDEFG

250-smtp.elong.com

250-PIPELINING

250-SIZE 20480000

250-ETRN

250-AUTH LOGIN PLAIN DIGEST-MD5 CRAM-MD5 (支持的身份验证机制种类: LOGIN, PLAIN等)

250 8BITMIME

AUTH LOGIN

334 VXNlcm5hbWU6 (Base64解码后: Username:)

bGlwaW5n (Base64编码前:的用户名 Alcatell)

334 UGFzc3dvcmQ6 (Base64解码后: Password:)

QWxjYXRlbGw (Base64编码前的密码: 123456)

235 Authentication successful

在程序执行时,用户名是:Alcatell, 密码是:123456,但是按照上面的步骤输入程序执行时却总是显示密码错误,什么原因呢?后来,我用Outlook Express 跟踪邮件发送日志,发现,原来密码验证时必须加一个重要的格式符号。

QWxjYXRlbGw (Base64编码前的密码: 123456)

就是这一句,必须改为:QWxjYXRlbGw= ,也就是说,必须加一个等号进来,否则密码验证不通过,即使你的密码是:123456,那么必须在123456对应的base64编码的后面加一个等号,否则,系统认为你的密码是错误的。

密码验证的代码如下:

// 验证用户名

sAuth = "bGlwaW5n\r\n"; // User: Alcatell

m_wsSMTPServer.Send( (LPCTSTR)sAuth, sAuth.GetLength() );

if( !get_response(USERNAME_SUCCESS,false) )

{

AfxMessageBox("USERNAME FAILURE");

m_wsSMTPServer.Close();

return FALSE;

}

// 验证密码 // Password:123456

sAuth = "QWxjYXRlbGw=\r\n";

m_wsSMTPServer.Send( (LPCTSTR)sAuth, sAuth.GetLength() );

if( !get_response(LOGIN_SUCCESS,false) )

{

AfxMessageBox("Login failure");

m_wsSMTPServer.Close();

return FALSE;

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航