下面由Laravel框架教程栏目给大家介绍Laravel 事件&异步处理,希望对需要的朋友有所帮助!
php aritsan make:event Test
事件和监听 listen 是一对多的管理,一个事件对应多个响应事件
定一个$data
属性,赋值触发事件时传递的数据。
public $data; /** * Create a new event instance. * * @return void */ public function __construct($data) { $this->data = $data; }
public function test(){ Test::dispatch('你好事件'); }
php artisan make:listener TestLisenter
namespace App\Lisenter;use App\Events\Test;class TestLisenter { public function handle(Test $test) { var_dump($test->data); //打印:你好事件 }}
这个时候我们要创建, listen 对象来处理业务逻辑
laravel 有提供两种方案:
在EventServiceProvider
添加$listen 数组信息比如:
/** * 应用程序的事件监听器映射 * * @var array */protected $listen = [ 'App\Events\Test' => [ 'App\Listeners\TestListenter', ],];
让系统自动处理,遍历指定目录
需要在EventServiceProvider
添加:
/** * 确定是否应自动发现事件和侦听器 * * @return bool */public function shouldDiscoverEvents(){ return true;}
/** * 获取应该用于发现事件的监听器的目录 * * @return array */ protected function discoverEventsWithin() { return [ $this->app->path('Lisenter'),//事件关联的监听器目录APP/Lisenters $this->app->path('Lisenter/test'),//事件关联的监听器目录APP/Lisenters/test ]; }
系统会自动的匹配Listen
此时, 已经完成了事件的流程。如果没有成功或者想知道更多事件的处理,比如,延时队列,判断是否要加入事件,处理失败之后的处理等等:参考文档
如果没有接触laravel 的队列的小伙伴,先参考: Laravel Jobs
只需要在 TestLisenter 实现 ShouldQueue 的接口即可
长这样:
namespace App\Lisenter;use App\Events\Test;use Illuminate\Contracts\Queue\ShouldQueue;class TestLisenter implements ShouldQueue{ public function handle(Test $test) { var_dump($test->data); //打印:你好事件 }}
以上是关于 Laravel 事件&异步处理的详细内容。更多信息请关注PHP中文网其他相关文章!