下面由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中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号