如何解决使用Laravel,Vue和Pusher订阅private-App.User.undefined所需的身份验证信息
我正在尝试使用带有laravel api的pusher发送在私有频道上广播的通知。发送通知时一切正常,推送服务器正在接收事件。但是,当我尝试收听这些事件时,控制台中什么也没有显示。推送程序中的错误日志显示以下内容:
这是我的main.js代码,用于收听广播
let userId=document.head.querySelector('meta[name="user-id"').content;
console.log(userId)
window.Echo.private('App.User.' + userId)
.notification((notification) => {
console.log(notification.type);
});
这是我的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,forceTLS: true,});
这是我来自welcome.blade.php的元标记
<meta name="csrf-token" content="{{ csrf_token() }}">
<meta name="user-id" content="{{Auth::check() ? Auth::user()->id:''}}">
这是我的channels.php文件代码
Broadcast::channel('App.User.{id}',function ($user,$id) {
return (int) $user->id === (int) $id;
},['guards'=>['api']]);
最后,来自BroadcastServiceProvider.php的启动功能
public function boot()
{
Broadcast::routes(['middleware' => ['auth:api']]);
require base_path('routes/channels.php');
}
任何帮助将不胜感激。谢谢。
解决方法
我有同样的问题,但使用 Djago 和 Javascript。我的建议是:
- 确保 Pusher 用于私人频道身份验证的 URL 有效
- “应用设置”中的“启用客户端事件”已开启
我正在努力解决同样的问题。根据我的阅读,如果您使用 api,则需要将身份验证标头添加到 bootstrap.js 文件中的 echo 实例,如下所示:
window.Echo = new Echo({
broadcaster: 'pusher',key: process.env.MIX_PUSHER_APP_KEY,cluster: process.env.MIX_PUSHER_APP_CLUSTER,forceTLS: true,auth:{
headers: {
Accept: 'application/json',Authorization: 'Bearer ',},});
试试这个。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。