扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
下面分析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;
}
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者