【问题标题】:How to debug Symfony Mailer delivery problems?如何调试 Symfony Mailer 交付问题?
【发布时间】:2021-10-02 07:17:39
【问题描述】:

我正在处理我的第一个 Symfony 5 项目,并且很难使用 MailerInterface 中的构建发送邮件。我之前在 Symfony 3 中使用过 Swift Mailer,之前从未遇到过类似的问题。

use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\Mailer\MailerInterface;
...

class SomeController extends AbstractController {
    public someAction(Request $request, MailerInterface $mailer) {
        ...
        $email = (new TemplatedEmail())
            ->from(new Address('address@example.com', 'My Symfony Mail'))
            //->to($user->getEmail())
            ->to('receiver@example.com')
            ->subject('Subject')
            ->htmlTemplate('email.html.twig');
    
        $mailer->send($email);
    }
}


// .env
#MAILER_DSN=smtp://user:pass@smtp.example.com:25
MAILER_DSN=sendmail://default

如果MAILER_DSN 有一些格式错误,则会抛出异常并显示在 Symfony 调试器页面上,例如The "invaliddsn" mailer DSN must contain a scheme... 这样看来配置的DSN smtp://user:pass@smtp.example.com:25 是正确的。在其他邮件应用程序中使用相同的凭据、主机和端口是没有问题的。

但是,当使用此代码时,不会显示错误/异常,而且我根本没有收到任何邮件。当然,我已经仔细检查了日志(没有错误),接收者垃圾邮件文件夹(没有)。指定 SMTP 服务器或 sendmail 没有任何区别。

Symfony docs 只解释了如何处理异常,但在我的例子中没有抛出异常。

虽然关于 Symfony 中的邮件问题还有很多其他问题,但其中大多数都涉及旧的 Swift Mailer 或其他特定问题。

如何判断邮件是已发送但未收到还是根本未发送?

【问题讨论】:

  • 你看过网页调试工具栏吗?它显示已发送的邮件。你试过mailcatcher吗?

标签: php symfony symfony-mailer


【解决方案1】:

如果它没有抛出异常,您可以假设传输没有引发错误条件。

来自docs

处理发送失败

当您的传输(SMTP 服务器或第三方提供商)接受邮件进行进一步递送时,Symfony Mailer 认为发送成功。由于您的提供程序中的某些问题,该消息稍后可能会丢失或无法传递,但这对于您的 Symfony 应用程序来说是遥不可及的。

如果在将电子邮件移交给您的传输时出现错误,Symfony 会抛出 Symfony\Component\Mailer\Exception\TransportExceptionInterface。捕获该异常以从错误中恢复或显示一些消息

你也可以check the object that send() returns:

Symfony\Component\Mailer\Transport\TransportInterfacesend() 方法返回的 Symfony\Component\Mailer\SentMessage 对象提供对原始消息 (getOriginalMessage()) 和一些调试信息 (getDebug()) 的访问,例如由 HTTP 完成的 HTTP 调用传输,这对于调试错误很有用。

最后,如果您有Symfony Web Profiler,由于您在 Web 请求期间进行发送,您可以检查分析器的输出以获取有关邮件发送尝试的信息。

【讨论】:

    猜你喜欢
    • 2019-11-30
    • 2021-12-27
    • 1970-01-01
    • 1970-01-01
    • 2021-01-29
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-11-22
    相关资源
    最近更新 更多