我已经创建了一个成功工作的邮件通知,但是当尝试对它进行队列时,我会得到以下错误:
Uncaught Exception: Serialization of 'Closure' is not allowed in /vendor/laravel/framework/src/Illuminate/Queue/Queue.php:125
下面是我认为是导致错误的代码:
public function toMail($notifiable)
{
$view_file = 'emails.verifyEmail';
$view = View::make($view_file, ['invitationToken' => $this->invitationToken, 'team_name' => $this->team->name, 'team_domain' => $this->team->domain ]);
$view = new HtmlString(with(new CssToInlineStyles)->convert($view));
return (new MailMessage)
->subject('Email Verification')
->view('emails.htmlBlank', ['bodyContent' => $view]);
}
我不太清楚它试图序列化的“闭包”是从哪里来的。我试着在->render()
上添加到View::make
的末尾,但这似乎没有什么区别。我相信这可能与MailMessage
的MailMessage
函数有关,但我不太确定。
再一次,这个通知在没有排队的时候工作得很好。
任何帮助都将不胜感激。
发布于 2017-07-25 12:55:35
即使这个问题很老,我也会把这个贴出来供将来参考。
当队列试图序列化通知实例时,会出现此问题。这是通过序列化通知对象的每个属性来完成的。我也有同样的问题,因为我做的事情
public function __construct(\Exception $ex){
$this->exception = $exception;
}
在我的通知课上。一旦通知被包装在SendQueuedNotification中,它将由队列处理程序序列化。在此过程中,SendQueuedNotification的每个属性都将被序列化,包括我们的自定义通知实例及其属性。当序列化程序尝试序列化$exception
实例时,一切都会失败;由于某种原因,异常类是不可序列化的,因为它可能在其属性中包含闭包。所以对我起作用的是修改构造函数,如下所示
public function __construct(\Exception $ex)
{
$this->exceptionClass = get_class($ex);
$this->exceptionMessage = $ex->getMessage();
$this->exceptionLine = $ex->getFile() . '@' . $ex->getLine();
$this->exceptionCode = $ex->getCode();
}
现在,所有通知属性都是完全可序列化的,并且一切都按预期工作。
另一种解决方案是使用__wakeup()
和__sleep()
方法自定义通知实例的序列化和反序列化。
希望它有助于理解你的问题。
https://stackoverflow.com/questions/43643626
复制相似问题