有谁知道 SwiftMailer 发送函数是否返回传递状态?我希望能够知道电子邮件已送达或未送达。这可能吗?
谢谢
SwiftMailer 支持至少三层检查,它们将报告几种类型的传递失败。
1) 始终检查 SwiftMailer 的 send() 或 batchSend() 命令的返回码是否有非零结果。从文档中:
//Send the message
$numSent = $mailer->send($message);
printf("Sent %d messages\n", $numSent);
/* Note that often that only the boolean equivalent of the
return value is of concern (zero indicates FALSE)
if ($mailer->send($message))
{
echo "Sent\n";
}
else
{
echo "Failed\n";
}
2) 使用failures-by-reference 功能来了解特定地址是否被拒绝或无法完成:
//Pass a variable name to the send() method
if (!$mailer->send($message, $failures))
{
echo "Failures:";
print_r($failures);
}
/*
Failures:
Array (
0 => receiver@bad-domain.org,
1 => other-receiver@bad-domain.org
)
*/
3) 在某些情况下,您可能还希望启用回执,以确认电子邮件阅读器显示了该消息。它们通常被用户或其电子邮件应用程序禁用或忽略,但如果您收到收据,则具有高度确认性。另请注意,这可能会在发送后很多天发生,因此它不是像上面两个那样的实时同步测试。
$message->setReadReceiptTo('your@address.tld');
但是,由于 SMTP 传递涉及到如此多的变量和系统层,因此通常不可能绝对确定消息是否已传递。您能做的最好的事情是确保您使用上面的前两项检查。如果您将自己的服务器用于 SMTP 服务,那么您还需要像 Marc B 提到的那样监视您的日志和队列。
另一个示例强调需要熟悉您正在使用的任何底层电子邮件系统。我刚刚开始使用 John Hobbs 为 Amazon Web Services SES 编写的 Swift_AWSTransport。SES 能够为通过它发送的每条消息返回带有诊断信息的 XML 响应。尽管 SwiftMailer 本身并不了解如何使用该 XML 响应,但我发现它对于解决交付问题非常宝贵。我提到它是因为我发现在某些情况下,上面的检查 #1 和 #2 对 SwiftMailer 来说似乎是成功的,但 SES 不喜欢我的邮件格式。因此,我正在考虑解析该 XML 作为附加检查。
相当旧的帖子,但从 Swiftmailer 4+ 开始,除了从方法调用中获取result
状态。send
如果您想调试邮件程序并查看传输过程中发生的情况,您可以使用 Logger 插件,甚至创建自己的插件。
https://swiftmailer.symfony.com/docs/plugins.html
$mailer = \Swift_Mailer::newInstance(
\Swift_SmtpTransport::newInstance('tls://smtp.gmail.com', 465)
);
$logger = new \Swift_Plugins_Loggers_ArrayLogger;
//$logger = new \Swift_Plugins_Loggers_EchoLogger; //echo messages in real-time
$mailer->registerPlugin(new \Swift_Plugins_LoggerPlugin($logger));
foreach ($recipients as $recipient) {
//...
$mailer->send(/*...*/);
}
echo $logger->dump(); //not needed if using EchoLogger plugin
它将为每个send
呼叫输出传输消息,看起来像
++ Starting Swift_SmtpTransport
<< 220 smtp.gmail.com ESMTP x12sm4143221vkc.19 - gsmtp
>> EHLO server.example.com
<< 250-smtp.gmail.com at your service, [192.168.1.1] 250-SIZE 35882577 250-8BITMIME 250-AUTH LOGIN PLAIN XOAUTH2 PLAIN-CLIENTTOKEN OAUTHBEARER XOAUTH 250-ENHANCEDSTATUSCODES 250-PIPELINING 250-CHUNKING 250 SMTPUTF8
>> AUTH LOGIN
<< 334 AbcDefGhIjKlMnop
>> AbcDefGhIjKlMnop==
<< 334 AbcDefGhIjKlMnop
>> AbcDefGhIjKlMnop==
<< 235 2.7.0 Accepted
++ Swift_SmtpTransport started
>> MAIL FROM:
<< 250 2.1.0 OK x12sm4143221vkc.19 - gsmtp
>> RCPT TO:<recipient@example.com>
<< 250 2.1.5 OK x12sm4143221vkc.19 - gsmtp
>> DATA
<< 354 Go ahead x12sm4143221vkc.19 - gsmtp
>> .
<< 250 2.0.0 OK 1468948643 x12sm4143221vkc.19 - gsmtp
Swiftmailer 与邮件的实际投递无关。它只是将事情交给您指定的任何 SMTP 服务器,并且由该服务器负责交付。您需要检查 SMTP 服务器的日志以了解邮件发生了什么。它可能会因为服务器被淹没而卡在传出队列中。它可能会卡在队列中,因为接收端无法访问或正在使用灰名单等... Swiftmailer 的工作在它从 SMTP 服务器得到邮件已排队的确认后结束。