小编给大家分享一下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事件之异步处理的示例”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。