首页 > 解决方案 > 使用 pusher 时如何修复 Laravel 5.7 中的“/broadcasting/auth 401 (Unauthorized)”错误

问题描述

我正在尝试在我的 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
      }
    }
});

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

我的 BroadcastServiceProvider 看起来像这样:

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

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

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

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

我还确保整个应用程序都使用 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);
    }
 }

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

 Echo.private('App.User.1')
 .notification('themechanged', (data) => {
     console.log(data)
  })

但在我的控制台中收到此错误: broadcasting/auth 401 (Unauthorized)

标签: phplaravelvuejs2jwtpusher

解决方案


推荐阅读