docker laravel でpusherでリアルタイムチャットを実装をしています。
メッセージを送るときに500エラーが出て困っています。
たまにですが、メッセージを送れる時もあります。
三日間いろいろなサイトを見てやったのですが、解決しなかったため質問しました。
ChatController.phpのイベント発火時にエラーが起きてchat.jsのajaxの部分でエラーた起きているのだと思います。
質問内容
問題がpusherの設定が間違っているのかを聞きたいです。
できればどこが間違っているのかも
よろしくお願いします。
bootstrap.js
import Echo from 'laravel-echo'; window.Pusher = require('pusher-js'); window.Echo = new Echo({ broadcaster: 'pusher', key: process.env.MIX_PUSHER_APP_KEY, client: process.env.MIX_PUSHER_APP_ID, cluster: process.env.MIX_PUSHER_APP_CLUSTER, encrypted: false, forceTLS: true });
.env
PUSHER_APP_ID=******* PUSHER_APP_KEY=******************** PUSHER_APP_SECRET=******************* PUSHER_APP_CLUSTER=ap3 MIX_PUSHER_APP_KEY="${PUSHER_APP_KEY}" MIX_PUSHER_APP_CLUSTER="${PUSHER_APP_CLUSTER}"
broadcasting.php
'default' => env('BROADCAST_DRIVER', 'pusher'), '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'), 'encrypted' => false, 'useTLS' => true, ], ], ],
ChatController.php
event(new ChatMessageRecieved($request->all()));
ChatMessageRecieved.php
namespace App\Events; use Illuminate\Broadcasting\Channel; use Illuminate\Broadcasting\InteractsWithSockets; use Illuminate\Broadcasting\PresenceChannel; use Illuminate\Broadcasting\PrivateChannel; use Illuminate\Contracts\Broadcasting\ShouldBroadcast; use Illuminate\Foundation\Events\Dispatchable; use Illuminate\Queue\SerializesModels; class ChatMessageRecieved implements ShouldBroadcast { use Dispatchable, InteractsWithSockets, SerializesModels; public $message; public $request; /** * Create a new event instance. * * @return void */ public function __construct($request) { $this->request = $request; } /** * イベントをブロードキャストすべき、チャンネルの取得 * * @return Channel|Channel[] */ public function broadcastOn() { return new Channel('my-channel'); } /** * ブロードキャストするデータを取得 * * @return array */ public function broadcastWith() { return [ 'message' => $this->request['message'], 'send' => $this->request['send'], 'recieve' => $this->request['recieve'], ]; } /** * イベントブロードキャスト名 * * @return string */ public function broadcastAs() { return 'my-event'; } }
chat.js
$(function() { $.ajaxSetup({ headers : { 'X-CSRF-TOKEN' : $('meta[name="csrf-token"]').attr('content'), }}); $('#btn_send').on('click' , function(){ console.log("ok"); $.ajax({ type : 'POST', url : '/chat/send', data : { message : $('textarea[name="message"]').val(), send : $('input[name="send"]').val(), recieve : $('input[name="recieve"]').val(), } }).done(function(result){ console.log("ok87"); $('textarea[name="message"]').val(''); }).fail(function(result){ }); }); console.log("ok97"); Pusher.logToConsole = true; console.log("ok98"); var pusher = new Pusher('***************', { cluster : 'ap3', }); var pusherChannel = pusher.subscribe('my-channel'); pusherChannel.bind('my-event', function(data) { console.log("ok2"); let appendText; let login = $('input[name="login"]').val(); if(data.send === login){ appendText = '<div class="send" style="text-align:right"><p>' + data.message + '</p></div> '; console.log("ok3"); }else if(data.recieve === login){ appendText = '<div class="recieve" style="text-align:left"><p>' + data.message + '</p></div> '; console.log("ok4"); }else{ console.log("ok5"); return false; } $("#room").append(appendText); }); });
500エラーが出た際はエラーログが残っていると思うので、まずはそれを確認してみて下さい。
回答1件
あなたの回答
tips
プレビュー