Laravel broadcastOn() в случае, если никогда не срабатывает
Я новичок в laravel и веб-сокетах. Мои веб-сокеты работают на панели инструментов laravel-websockets, и теперь я пытаюсь вызвать событие веб-сокета с помощью этой команды javascript:
axios.post('updatequeue', {queue_position: newPos});
newPos - это число.
Это мой метод контроллера:
public function updateQueue(Request $request){
$queueposition = $request->input('queue_position');
event(new QueueUpdate($queueposition));
}
Это мое событие:
class QueueUpdate implements ShouldBroadcast
{
use Dispatchable, InteractsWithSockets, SerializesModels;
public $queue_position;
/**
* Create a new event instance.
*
* @return void
*/
public function __construct($queue_position)
{
$this->queue_position = $queue_position;
}
/**
* Get the channels the event should broadcast on.
*
* @return \Illuminate\Broadcasting\Channel|array
*/
public function broadcastOn()
{
return new Channel('sessionid');
}
}
Когда я слежу за событиями на панели инструментов, ничего не отображается. Я получаю ответ 200 на запрос axios. Я разместил журналы повсюду, и вызывается мой метод событий __construct, но broadcastOn() нет. Я действительно застрял здесь, если у кого-то есть идеи, буду очень признателен.
РЕДАКТИРОВАТЬ
вот мой broadcasting.php:
<?php
return [
'default' => env('BROADCAST_DRIVER', 'null'),
'connections' => [
'pusher' => [
'driver' => 'pusher',
'key' => env('PUSHER_APP_KEY'),
'secret' => env('PUSHER_APP_SECRET'),
'app_id' => env('PUSHER_APP_ID'),
'options' => [
'cluster' => env('PUSHER_APP_CLUSTER'),
'host' => env('WEBSOCKET_BROADCAST_HOST'),
'port' => env('WEBSOCKET_BROADCAST_PORT'),
'scheme' => env('WEBSOCKET_SCHEME'),
'encrypted' => env('WEBSOCKET_ENCRYPTED'),
],
],
'redis' => [
'driver' => 'redis',
'connection' => 'default',
],
'log' => [
'driver' => 'log',
],
'null' => [
'driver' => 'null',
],
],
];
и websockets.php:
<?php
use BeyondCode\LaravelWebSockets\Dashboard\Http\Middleware\Authorize;
return [
'dashboard' => [
'port' => env('LARAVEL_WEBSOCKETS_PORT', 6001),
],
'apps' => [
[
'id' => env('PUSHER_APP_ID'),
'name' => env('APP_NAME'),
'key' => env('PUSHER_APP_KEY'),
'secret' => env('PUSHER_APP_SECRET'),
'enable_client_messages' => false,
'enable_statistics' => true,
],
],
'app_provider' => BeyondCode\LaravelWebSockets\Apps\ConfigAppProvider::class,
'allowed_origins' => [
//
],
'max_request_size_in_kb' => 250,
'path' => 'laravel-websockets',
'middleware' => [
'web',
Authorize::class,
],
'statistics' => [
'model' => \BeyondCode\LaravelWebSockets\Statistics\Models\WebSocketsStatisticsEntry::class,
'interval_in_seconds' => 60,
'delete_statistics_older_than_days' => 60,
'perform_dns_lookup' => false,
],
'ssl' => [
'local_cert' => env('LARAVEL_WEBSOCKETS_SSL_LOCAL_CERT', null),
'local_pk' => env('LARAVEL_WEBSOCKETS_SSL_LOCAL_PK', null),
'passphrase' => env('LARAVEL_WEBSOCKETS_SSL_PASSPHRASE', null),
'verify_peer' => env('LARAVEL_WEBSOCKETS_SSL_VERIFY_PEER', true),
],
'channel_manager' => \BeyondCode\LaravelWebSockets\WebSockets\Channels\ChannelManagers\ArrayChannelManager::class,
];
РЕДАКТИРОВАТЬ
Я местный. Вот значения для broadcasting.php:
'driver' => 'pusher',
'key' => portalkey,
'secret' => secret,
'app_id' => portalID,
'cluster' => portalcluster,
'host' => 127.0.0.1,
'port' => 6001,
'scheme' => http,
'encrypted' => false,
3 ответа
Если вы можете подключиться к laravel-websockets
панель управления, но события не отображаются, скорее всего, вы /laravel-websockets/auth
запрос не выполняется из-за токена csrf. Попробуйте добавитьlaravel-websockets
к $except
переменная в VerifyCsrfToken
промежуточное ПО.
Для родственных душ, которые могут заинтересоваться этим вопросом. У меня был похожий опыт.
The broadcastOn()
метод не вызывался, но событие завершается без каких-либо ошибок. Я проверил это, поместив регистратор перед оператором возврата (тот, который возвращает канал).
Мое решение (на момент написания) заключалось в реализацииShouldBroadCastNow
интерфейс вместоShouldBroadCast
и обеспечение того, чтобы вызывающий класс не находился в очереди.
Таким образом, синхронное выполнение работает.
Кажется немного странным, что нахождение в очереди приводило к тихому сбою, но вот в чем дело.
You should set the QUEUE_CONNECTION=sync
in your .env
file.
This will make the broadcast work and fix your problem.