CakePHP 3.x - 在调试期间通过电子邮件记录而不是发送

CakePHP 3.x - Email to log instead of sending during debug

我想将我的应用程序切换到实际不发送电子邮件但保存到日志文件的配置。
这样我就可以正常测试我的应用程序,而不用担心不小心给数百个用户发邮件,也不用给自己发垃圾邮件。

我认为 EmailTransports 可能是一个解决方案。例如,当使用 DebugTransport 时根本不发送电子邮件,而是仅由 ->send() 函数返回邮件内容。

这种传输的缺点是我必须修改控制器代码才能显示内容,我想避免这种情况。

那么有没有一种配置可以将电子邮件存储到文件而不是发送出去,例如:

[root]
    logs/
         emails/
             2019-10-01_15:32_email@example.com.txt
             2019-10-01_16:54_another_recipient@example.com.txt
             ...

没有这样的内置配置,不,但是您可以轻松创建自己的自定义传输,将电子邮件记录到文件而不是发送它们。

这是一个非常基本的示例传输,它扩展了调试传输,并将数据写入自定义 logging scope:

namespace App\Mailer\Transport;

use Cake\Log\LogTrait;
use Cake\Mailer\Email;
use Cake\Mailer\Transport\DebugTransport;
use Psr\Log\LogLevel;

class TestTransport extends DebugTransport
{
    use LogTrait;

    public function send(Email $email)
    {
        $data = parent::send($email);
        $this->log(json_encode($data), LogLevel::DEBUG, ['scope' => ['emails']]);

        return $data;
    }
}

另见