首先声明 事件 和 监听者 的对应关系 在 EventServiceProvider.php 的 $listen 数组中
类似:
protected $listen = [
//'App\Events\Event' => [
// 'App\Listeners\EventListener',
//],
'App\Events\UserLogin' => [
'App\Listeners\UserLoginListener',
], // 自定义事件
'Illuminate\Auth\Events\Login' => [
'App\Listeners\IlluminateUserLoginListener',
], // 使用系统的事件
];
然后使用 php artisan event:generate 来生成基础代码 (已经存在的事件文件 比如 Illuminate\Auth\Events\Login.php 不会重复创建)
修改 生成的 app/Events/UserLogin.php 如下: 即添加 user 类型提示
<?php
namespace App\Events;
use App\User;
use Illuminate\Broadcasting\Channel;
use Illuminate\Queue\SerializesModels;
use Illuminate\Broadcasting\PrivateChannel;
use Illuminate\Broadcasting\PresenceChannel;
use Illuminate\Foundation\Events\Dispatchable;
use Illuminate\Broadcasting\InteractsWithSockets;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;
class UserLogin
{
use Dispatchable, InteractsWithSockets, SerializesModels;
public $user;
/**
* Create a new event instance.
*
* @return void
*/
public function __construct(User $user)
{
$this->user = $user;
}
/**
* Get the channels the event should broadcast on.
*
* @return Channel|array
*/
public function broadcastOn()
{
return new PrivateChannel('channel-name');
}
}
然后修改
app/Listeners/UserLoginListener.php
<?php
namespace App\Listeners;
use App\Events\UserLogin;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;
use Log;
class UserLoginListener
{
/**
* Create the event listener.
*
* @return void
*/
public function __construct()
{
//
}
/**
* Handle the event.
*
* @param UserLogin $event
* @return void
*/
public function handle(UserLogin $event)
{
Log::info('in user login listener custom event and listener');
Log::info($event->user);
}
}
最后定义事件分发(触发)代码即可:
在 LoginController 的 login函数 登录完成逻辑后面添加:
event(new UserLogin($request->user()));
这样就完成了 事件的分发。
以上只是事件使用的举例,实际上 登录事件 系统已经定义好了, 当然系统还定义了很多其它的事件。
例如缓存的命中 和 miss 数据库的查询 事务开始等等。
但是如何列出所有的事件,我是通过下面的方法:
使用搜索文件 列出所有 文件夹 叫做 Events 的搜索结果 然后基本上就是系统定义好的事件了,我的搜索编辑器(php storm)自带的
但是这个方法明显不是最有效的,所以如果大侠知道,还希望助一臂之力。
使用方法 :
如上 event service 已经定义了
'Illuminate\Auth\Events\Login' => [
'App\Listeners\IlluminateUserLoginListener',
], // 使用系统的事件
这里的 Illuminate\Auth\Events\Login 和 事件分发 都是系统定义好的 ,你只需要实现 App\Listeners\IlluminateUserLoginListener 即可
在刚才 php artisan event:generate 的时候已经生成了 listen 文件了 在 app\Listeners\IlluminateUserLoginListener.php
根据实际 修改 handle 函数即可。
另外想要查看 事件分发 可以搜索 比如 缓存命中 。 首先会看到 Cache 下面的 Events 文件夹 有个 CacheHit.php 那么 全局搜索 CacheHit 即可
具体在
vendor\laravel\framework\src\Illuminate\Cache\Repository.php
当然 像 Login 这些就比较多不好找了,可以根据实际 逻辑 慢慢分析 也是找的到的。
大部分 系统定义的事件分发 调用方式有两种:
使用 event
$this->event(new CacheHit($key, $value));
使用 dispatch
return $this->events->dispatch(new Events\TransactionBeginning($this));
此文章通过 python 爬虫创建,原文是自己的csdn 地址: laravel5 列出所有事件 和事件实例