Laravel事件没有解雇?

时间:2016-10-29 19:17:51

标签: laravel laravel-5 laravel-5.2 laravel-events

我似乎无法让任何eloquent.saved事件处理程序运行。

我试过了:

<?php

namespace App\Providers;

use Illuminate\Contracts\Events\Dispatcher as DispatcherContract;
use Illuminate\Foundation\Support\Providers\EventServiceProvider as ServiceProvider;

class EventServiceProvider extends ServiceProvider
{
    protected $listen = [
        'eloquent.saved: \App\Models\Company' => [
            '\App\Models\Company@hasSaved',
        ],
    ];

}

然后将此方法添加到\App\Models\Company

public function hasSaved() {
    die("SAVED!!!");
}

但是当我保存公司时,它不会运行。

我尝试创建一个观察者:

<?php

namespace App\Providers;

use App\Models\Company;
use App\Observers\CompanyObserver;
use DB;
use Illuminate\Support\ServiceProvider;

class AppServiceProvider extends ServiceProvider
{

    public function register()
    {
        Company::observe(CompanyObserver::class);
    }
}

但事件永远不会发生:

<?php namespace App\Observers;

class CompanyObserver {

    public function saved() {
        die('saved');
    }

    public function saving() {
        die('saving');
    }
}

我尝试在EventServiceProvider中使用侦听器类:

protected $listen = [
    'eloquent.saved: \App\Models\Company' => [
        \App\Listeners\CompanySavedListener::class,
    ],
];

但这也永远不会运行。

最后,我尝试将其添加到EventServiceProvider

public function boot(DispatcherContract $events)
{
    parent::boot($events);

    $events->listen('eloquent.*', function() {
        dump(func_get_args());
    });
}

这确实引发了一堆随机事件,但它只是在向我提供模型实例 - 我不知道实际发生了什么事件。

那是怎么回事?我只是想知道我的Company已保存的时间。

1 个答案:

答案 0 :(得分:2)

我们选择Observer方式。问题是你使用过:

Company::observe(CompanyObserver::class);
register的{​​{1}}方法中

,您应该在AppServiceProvider方法中使用它。当您将此行移至boot方法(同一类)时,它将正常运行,当您保存公司时,应启动boot saved方法的代码。