Laravel Echo 500 错误(广播/身份验证)?

Man*_*yen 4 php pusher vuejs2 laravel-echo laravel-5.4

祝你今天过得愉快 !

我有一个问题:我设置了 Laravel Echo & Pusher,但遇到了这个错误,不知道如何解决 :(

在此处输入图片说明

我检查了我的 app-key、app-cluster,但都是正确的。

有人能帮我吗?

应用程序.js

const app = new Vue({
    el: '#app',
    data: {
        messages: []
    },
    methods:{
        addMessage(message){
            this.messages.push(message);
            axios.post('/messages', message).then(response => {
               console.log(response);
            });
        }
    },
    created(){
        axios.get('/messages').then(response => {
            this.messages = response.data;
        });

        Echo.channel('chatroom')
            .listen('MessageEvent', (e) => {
                console.log(e);
            });
    }
})
Run Code Online (Sandbox Code Playgroud)

引导程序.js

import Echo from 'laravel-echo'

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

window.Echo = new Echo({
    broadcaster: 'pusher',
    key: '************',
    cluster: 'ap1',
    encrypted: false
});
Run Code Online (Sandbox Code Playgroud)

消息事件

use Dispatchable, InteractsWithSockets, SerializesModels;
public $message, $user;

public function __construct(Message $message, User $user)
{
    $this->message = $message;
    //query
    $this->user = $user;
}

public function broadcastOn()
{
    return new PresenceChannel('chatroom');
}
Run Code Online (Sandbox Code Playgroud)

频道.php

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

Broadcast::channel('chatroom', function ($user, $id) {
    return $user;
});
Run Code Online (Sandbox Code Playgroud)

Ale*_*lex 5

错误403或500 /广播/与Laravel版本> 5.3&推权威性,你需要改变你的代码资源/资产/ JS / bootstrap.js

window.Echo = new Echo({
    broadcaster: 'pusher',
    key: 'your key',
    cluster: 'your cluster',
    encrypted: true,
    auth: {
        headers: {
            Authorization: 'Bearer ' + YourTokenLogin
        },
    },
});
Run Code Online (Sandbox Code Playgroud)

app/Providers/BroadcastServiceProvider.php 中更改为

Broadcast::routes()
Run Code Online (Sandbox Code Playgroud)

Broadcast::routes(['middleware' => ['auth:api']]);
Run Code Online (Sandbox Code Playgroud)

或者

Broadcast::routes(['middleware' => ['jwt.auth']]); //if you use JWT
Run Code Online (Sandbox Code Playgroud)

它对我有用,希望对你有帮助。