使用 Zend_Mail 通过 Exchange Server 发送 SMTP 电子邮件 - 如何诊断这些错误

Posted

技术标签:

【中文标题】使用 Zend_Mail 通过 Exchange Server 发送 SMTP 电子邮件 - 如何诊断这些错误【英文标题】:Send SMTP Email through Exchange Server Using Zend_Mail - How to Diagnose these Errors 【发布时间】:2011-04-24 12:46:16 【问题描述】:

我有以下代码:

$config = array(
   'auth' => 'login',
   'username' => 'domain\user',
   'password' => 'password',
   'ssl' => 'tls',
   'port' => 25,
);

$tr = new Zend_Mail_Transport_Smtp('192.168.101.11',$config);
Zend_Mail::setDefaultTransport($tr);

$mail = new Zend_Mail();
$mail->setBodyText($text);
$mail->setFrom('noreply@domain.com');
$mail->addTo($user->getEmail());
$mail->setSubject('Email subject');
$mail->send();

当我尝试使用正确的凭据进行连接时,我在日志中收到以下错误:

2010-10-12T13:00:59-07:00 ERR (3): AdminController::emailPassword - 5.7.1
2010-10-12T13:00:59-07:00 ERR (3): AdminController::emailPassword - #0 /usr/share/php/Zend/Mail/Protocol/Smtp.php(261): Zend_Mail_Protocol_Abstract->_expect(250, 300)
        #1 /usr/share/php/Zend/Mail/Transport/Smtp.php(207): Zend_Mail_Protocol_Smtp->mail('noreply@domain...')
        #2 /usr/share/php/Zend/Mail/Transport/Abstract.php(348): Zend_Mail_Transport_Smtp->_sendMail()
        #3 /usr/share/php/Zend/Mail.php(1178): Zend_Mail_Transport_Abstract->send(Object(Zend_Mail))
...

当我尝试使用绝对错误的密码连接并发送电子邮件时,我收到以下错误:

2010-10-12T13:03:52-07:00 ERR (3): AdminController::emailPassword - 5.7.3
2010-10-12T13:03:52-07:00 ERR (3): AdminController::emailPassword - #0 /usr/share/php/Zend/Mail/Protocol/Smtp/Auth/Login.php(95): Zend_Mail_Protocol_Abstract->_expect(235)
#1 /usr/share/php/Zend/Mail/Protocol/Smtp.php(217): Zend_Mail_Protocol_Smtp_Auth_Login->auth()
#2 /usr/share/php/Zend/Mail/Transport/Smtp.php(200): Zend_Mail_Protocol_Smtp->helo('localhost')
#3 /usr/share/php/Zend/Mail/Transport/Abstract.php(348): Zend_Mail_Transport_Smtp->_sendMail()
#4 /usr/share/php/Zend/Mail.php(1178): Zend_Mail_Transport_Abstract->send(Object(Zend_Mail))
#5 /var/www/mreserve/application/controllers/AdminController.php(458): Zend_Mail->send()
...

我的问题,我真的不知道如何诊断这些错误。我在哪里查找 5.7.1 和 5.7.3 错误代码的描述等?谷歌并没有帮助我太多。当我为我的个人 GMail 帐户插入凭据时,我可以正常发送邮件,因此我知道如果配置正确,我可以发送电子邮件。

其他一些可能有用的花絮,我正在尝试从为该用户创建电子邮件帐户的公司 Exchange 发送,我正在尝试发送到域外的电子邮件,但我没有很多访问交换服务器 - 除了一些关于他们如何设置电子邮件客户端的屏幕截图。

【问题讨论】:

【参考方案1】:

这些是 Exchange 服务器的 NDR(未送达报告)代码。 Here is a (rather old) blog entry describing them 和 another page listing the sames codes 用于交换 2007。

5.7.1 错误代码

“权限问题”,可能指向:

SMTP relay problem。您的帐户无权向其他域发送电子邮件。 发件人/收件人问题。您的帐户无权向讨论列表发送电子邮件(因为您的帐户不是其中的成员) 您帐户的其他特定限制。

恕我直言,只有 SMTP 日志才能说明确切原因。

5.7.3 错误代码

“发件人被禁止”或“未授权,安全问题”,取决于来源;可能与错误的密码提交一致。

希望这会有所帮助。

【讨论】:

非常感谢您的链接。有了这些指导我,我能够将 Exchange 服务器管理员指向正确的方向来解决问题。我不知道最终的解决方案是什么,但我知道他们必须最终修复它,至少我的代码没有错! 太棒了!第 1 课:总是将其归咎于 Exchange(开个玩笑)

以上是关于使用 Zend_Mail 通过 Exchange Server 发送 SMTP 电子邮件 - 如何诊断这些错误的主要内容,如果未能解决你的问题,请参考以下文章

Zend_Mail - 通过 POP 阅读 Gmail 邮件

使用 Zend_mail 时,我的电子邮件似乎被视为垃圾邮件,通过 Outlook 发送而没有?

如何预览 Zend_Mail 的 HTML 代码?

使用 Zend_Mail 获取邮件源

使用 Zend_Mail 时添加 PDF 附件

Zend_Mail 在邮件正文中带有法语字符