当前位置 : 主页 > 编程语言 > 其它开发 >

关于 Laravel 事件&异步处理

来源:互联网 收集:自由互联 发布时间:2021-08-14
下面由 Laravel 框架教程栏目给大家介绍Laravel 事件异步处理,希望对需要的朋友有所帮助! 生成事件 php aritsan make:event Test 事件和监听 listen 是一对多的管理,一个事件对应多个响应事件

下面由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 事件&异步处理的详细内容,更多请关注自由互联其它相关文章!

网友评论