使用 Pusher 时如何修复 Laravel 5.7 中的“/broadcasting/auth 401(未经授权)”错误

Joh*_*Dev 5 php jwt laravel pusher vuejs2

我正在尝试在我的 SPA 中设置推送器。我已经在 Laravel 5.7 和 Vus js 中开发了该应用程序,并使用 jwt 进行身份验证。

我的 Boostrap.js 看起来像这样:

window.Echo = new Echo({
broadcaster: 'pusher',
key: process.env.MIX_PUSHER_APP_KEY,
cluster: process.env.MIX_PUSHER_APP_CLUSTER,
encrypted: true,
auth: {
    headers: {
        Authorization: JWTtoken
      }
    }
});
Run Code Online (Sandbox Code Playgroud)

JWTtoken我登录后从 JWT 获取令牌。

我的 BroadcastServiceProvider 如下所示:

我在 config/app.php 中取消了它的注释

class BroadcastServiceProvider extends ServiceProvider
{
    public function boot()
     {
       Broadcast::routes(['middleware' => 'jwt.auth']);
       require base_path('routes/channels.php');
     }
}
Run Code Online (Sandbox Code Playgroud)

我的 Channels.php 文件如下所示:

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

我还确保整个应用程序使用 jwt 作为其唯一的身份验证方法

配置/auth.php

我的事件名为 UserEvent 看起来像这样:

class UserEvent implements ShouldBroadcast
{
    use Dispatchable, InteractsWithSockets, SerializesModels;
    public $user;

    public function __construct(User $user)
    {
       $this->user = $user;
    }

    public function broadcastAs()
    {
       return 'themechanged';
    }

    public function broadcastOn()
    {
        return new PrivateChannel('App.User.'.$this->user->id);
    }
 }
Run Code Online (Sandbox Code Playgroud)

然后在我的 vue 组件中我这样做了:

 Echo.private('App.User.1')
 .notification('themechanged', (data) => {
     console.log(data)
  })
Run Code Online (Sandbox Code Playgroud)

但我的控制台中出现此错误: broadcasting/auth 401 (Unauthorized)