Laravel中带有推动器的500(内部服务器错误)

时间:2020-04-08 17:18:28

标签: laravel vue.js websocket laravel-echo pusher-js

我正在通过Vue.js,Laravel-echo和pusher使用Laravel 7。 当我在vue中呼叫事件时,我收到500 (Internal Server Error)

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,
    cluster: process.env.MIX_PUSHER_APP_CLUSTER,
    encrypted: true
});

vue代码

 listen: function() {
                Echo.channel('commentsChannel')
                    .listen('NewComment', (comment) => {
                    // this.comments.unshift(comment);
                    console.log('yessss');
                    })
            }

事件:NewComment.php

<?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;  //for queueing 
use Illuminate\Contracts\Broadcasting\ShouldBroadcastNow;  //for no queueing 
use Illuminate\Foundation\Events\Dispatchable;
use Illuminate\Queue\SerializesModels;

use App\Comment;

class NewComment implements ShouldBroadcast
{
    use Dispatchable, InteractsWithSockets, SerializesModels;

    public $comment;
    /**
     * Create a new event instance.
     *
     * @return void
     */
    public function __construct(Comment $comment)
    {
        $this->comment = $comment;
    }

    /**
     * Get the channels the event should broadcast on.
     *
     * @return \Illuminate\Broadcasting\Channel|array
     */
    public function broadcastOn()
    {
        return new Channel('commentsChannel');
    }
}

routes / channels.php

<?php

use Illuminate\Support\Facades\Broadcast;

Broadcast::channel('App.User.{id}', function ($user, $id) {
    return (int) $user->id === (int) $id;
});

对此错误有解决方案吗?!或我们如何调试并更多地了解此错误? 预先感谢您的帮助!

1 个答案:

答案 0 :(得分:-1)

bootstrap.js:提供密钥和集群

import Echo from 'laravel-echo';

window.Pusher = require('pusher-js');

window.Echo = new Echo({
    broadcaster: 'pusher',
    key: 'XXXXXXXXXX',
    cluster: 'XXX',
    forceTLS: true
});