3

我正在使用 Laravel Mailable 发送电子邮件,并且我想记录已成功发送的电子邮件。

Laravel Mailable 具有在发送电子邮件后触发的默认事件

https://laravel.com/docs/5.6/mail#events

所以我把我的听众钩到这个事件上

protected $listen = [
        'App\Events\Event' => [
            'App\Listeners\EventListener',
        ],
        'Illuminate\Mail\Events\MessageSent' => [
            'App\Listeners\LogSentEmailNotification',
        ],
    ];

侦听器处理程序

public function handle(MessageSent $event)
{

    //get extra data 
    $job_request_id = $event->message->job_request_id;

    $message = $event->message;

    $data = [
        'job_request_id' => $job_request_id,
        'to' => $message->getHeaders()->get('To'),
        'from' => $message->getHeaders()->get('From'),
        'cc' => $message->getHeaders()->get('Cc'),
        'bcc' => $message->getHeaders()->get('Bcc'),
        'subject' => $message->getHeaders()->get('Subject')->getFieldBody(),
        'body' => $message->getBody(),
    ];

    $email_notification_log = $this->email_notification_log->create($data);
}

额外数据 job_request_id 从 Mailable 类 CustomEmailNotification.php 中的 build() 方法传递

class CustomEmailNotification extends Mailable implements ShouldQueue
{

    public function build()
    {
        $job_request_id = 1;

        //pass extra data mail message            

        $this->withSwiftMessage(function ($message) use($job_request_id){
            $message->job_request_id = $job_request_id;
        });
    }
}

现在,Listener 类上的这一行在没有队列的情况下工作正常,但是当使用队列时,它将返回 null

 //get extra data 
 $job_request_id = $event->message->job_request_id;
 var_dump($job_request_id);
 //null when using queue

问题是,使用队列时将自定义数据传递给 MailSent 事件的正确方法是什么?

还是在使用队列并传递给 withSwiftMessage() 时可能会丢失 job_request_id,因此事件侦听器刚刚收到空值?

谢谢

4

3 回答 3

2

publicMailable 上的任何属性都将保存到data事件中的属性中。

class CustomEmailNotification extends Mailable implements ShouldQueue
{
    public $job_request_id = 1;
}

现在在您的侦听器中,您可以将属性名称作为数组索引data

var_dump($event->data['job_request_id']);
于 2018-12-03T16:10:13.953 回答
2

如果您将主管用作队列工作者。尝试重新启动所有进程。必须重新加载主管以反映您的代码的最新更改。

sudo supervisorctl restart all
于 2018-05-25T04:41:51.617 回答
0

Mabey 这可以帮助你 https://medium.com/@guysmilez/queuing-mailables-with-custom-headers-in-laravel-5-4-ab615f022f17

根据this post,当您将mailable放入队列时变量会丢失,因此您必须覆盖Mailable的发送方法

于 2018-07-25T13:47:14.560 回答