我有一个Lumen控制器类,可以在创建用户时触发事件。我正在使用事件调度程序。该事件应该被触发,但是侦听器不处理该事件。 我确信我已经遵循了Lumen文档的每一步。
// UserController.php
class UserController extends ApiController
{
protected $event = null;
public function __construct(Dispatcher $event)
{
$this->event = $event;
}
/**
* Store a newly created resource in storage.
*
* @param Request $request
* @return Response
*/
public function store(Request $request)
{
$this->acceptContentType($request, 'json');
$this->input = $request->json()->all();
$this->withEncryptedParameters();
$this->validateParameterNames(array_keys($this->validationRules));
$this->validateParameterContent($this->validationRules);
$roles = $this->getRelationInput('roles');
$user = User::create($this->input);
$this->addRelation($user, $roles, Role::class, 'roles');
$this->event->fire(new UserCreated($user));
return $this->respondCreated($user->id);
}
}
所以我基本上想要将用户存储到数据库中,并在发生这种情况时触发事件。
// UserCreated.php
class UserCreated extends Event
{
public $user;
public function __construct(User $user)
{
$this->user = $user;
}
}
事件被正确触发,所以如果我将“echo”或“var_dump”放入事件的构造函数中,我可以看到它有效。如果我对听众如此相同,则不会做出反应。
// UserCreatedEmail.php
class UserCreatedEmail extends Listener
{
public function handle(UserCreated $event)
{
echo 'Hello?';
}
}
我已在EventServiceProvider中注册了它。
// EventServiceProvider.php
class EventServiceProvider extends ServiceProvider
{
/**
* The event listener mappings for the application.
*
* @var array
*/
protected $listen = [
UserCreated::class => [
UserCreatedEmail::class
]
];
}
并在引导区域取消注释。
// bootstrap/app.php
$app->register(WISSIT\UserService\Providers\EventServiceProvider::class);
我完全不知道为什么不起作用。我可以使用“$ event-> listen”但是当我使用测试时它也会听。根据Lumen的文档,它应该没有它。
是的,命名空间设置正确。不,我不想使用外墙。
答案 0 :(得分:9)
在“注册服务提供商”下的bootstrap / app.php中注释服务提供商的注册。
lintOptions {
checkReleaseBuilds false
}
进入
// $app->register(App\Providers\EventServiceProvider::class);
答案 1 :(得分:0)
我想我已经遇到了这个问题,所以我就是这样解决的:
在EventServiceProvider
将事件类和侦听器类更改为实际路径时,请勿在{{1}}中使用::class
。即:
EventServiceProvider
答案 2 :(得分:0)
好的,所以看起来只有在控制器中使用\Illuminate\Contracts\Event\Dispatcher
时才会收听事件。我用了\Illuminate\Events\Dispatcher
。我不知道为什么会这样,但它确实有效。
答案 3 :(得分:0)
在使用Lumen和事件监听器时,我遇到了类似的问题。被解雇的事件从未到达我的自定义听众,我正在努力寻找问题所在的一天。
最后我发现,我的听众上有handle
方法的错误签名。这是我的错误,但Dispatcher
没有通知我这个问题。当我改变方法接受给定的参数时,它才开始工作。
我认为问题在于Illuminate\Events\Dispatcher
方法中的fire
。如果方法的签名错误,函数call_user_func_array
将返回false,但调度程序在出错时突然退出循环。并且不会通知用户有关问题。