有没有人知道SwiftMailer发送函数是否返回传递状态?我希望能够知道电子邮件已发送或未发送。这可能吗?
由于
答案 0 :(得分:36)
SwiftMailer支持至少三层检查,它们会报告几种类型的交付失败。
1)始终检查SwiftMailer的send()或batchSend()命令的返回码是否为非零结果。来自the documentation:
//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 feature了解特定地址是否被拒绝或无法完成:
//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)在某些情况下,您可能还需要enable return receipts,这可以确认电子邮件阅读器是否显示了该消息。他们经常被用户或他们的电子邮件应用程序禁用或忽略,但如果您收到收据,则会非常确认。另请注意,这可能在发送后的许多天内发生,因此它不是像上面两个那样的实时同步测试。
$message->setReadReceiptTo('your@address.tld');
但是,由于SMTP传递中涉及的系统变量和层数太多,因此通常无法确定是否已传递消息。您可以做的最好的事情是确保您使用上面的前两个检查。如果您使用自己的服务器进行SMTP服务,那么您还需要像Marc B所提到的那样关注您的日志和队列。
另一个例子强调需要熟悉您正在使用的任何底层电子邮件系统。我刚刚开始使用John Hobbs为亚马逊网络服务SES提供的Swift_AWSTransport。 SES能够返回XML响应,其中包含通过它发送的每条消息的诊断信息。尽管SwiftMailer本身并不了解如何使用该XML响应,但我发现它对于交付故障排除非常宝贵。我之所以提到它,是因为我发现在某些情况下,上面的#1和#2检查对SwiftMailer来说似乎是成功的,但是SES不喜欢我的消息格式化。因此,我正在考虑将该XML解析为附加检查。
答案 1 :(得分:6)
相当古老的帖子,但是从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
答案 2 :(得分:4)
Swiftmailer与邮件的实际发送无关。它只是将你的东西交给你指定的任何SMTP服务器,它就是负责交付的服务器。您需要检查SMTP服务器的日志以查看邮件发生了什么。它可能会卡在传出队列中,因为服务器已被淹没。它可能会卡在队列中,因为接收端无法访问或正在使用灰名单等...一旦从SMTP服务器收到邮件已经排队的确认,Swiftmailer的工作就会结束。