0

0

Laravel中如何实现广播推送功能_Laravel Broadcasting与Pusher配置【深入】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-27 13:08:57

|

524人浏览过

|

来源于php中文网

原创

Laravel 官方已弃用 Pusher,主推自托管的 laravel/reverb;若仍用 Pusher,需手动配置 v2 认证头、正确路由、频道鉴权及用户上下文传递,并注意 Reverb 的部署与跨域限制。

laravel中如何实现广播推送功能_laravel broadcasting与pusher配置【深入】

Pusher 不再是 Laravel 广播的默认或推荐方案,官方已转向 laravel/reverb 作为首推的自托管广播服务器;若仍需用 Pusher,必须手动配置并注意其 API v1 已停用、v2 的认证机制和事件命名规则变更。

为什么 pusher-php-server v7+ 无法通过 authEndpoint 验证?

Pusher v2 要求所有私有/存在频道的鉴权请求必须携带 X-Pusher-KeyX-Pusher-Socket-ID 头,并返回严格格式的 JSON(含 auth 字段),而旧版 Laravel 的 Broadcast::routes() 默认不校验这些头。

  • 确保在 routes/channels.php 中显式启用鉴权路由
    Broadcast::routes(['middleware' => ['web', 'auth:sanctum']]);
  • config/broadcasting.phppusher 配置中,host 必须设为 api-region.pusher.com(如 api-us2.pusher.com),不能用 ws-*.pusher.com
  • 前端初始化时,authEndpoint 必须指向 Laravel 的 /broadcasting/auth,且该端点需返回形如 {"auth":"v1...:..."} 的响应,不能多字段、不能带空格

Broadcast::channel() 回调里 $user 为什么是 null?

因为 Sanctum 或 Passport 的中间件未正确传递用户上下文到广播通道闭包——Laravel 广播鉴权不走常规 HTTP 请求生命周期,而是复用当前会话或 Token,但默认不自动解析。

唱鸭
唱鸭

音乐创作全流程的AI自动作曲工具,集 AI 辅助作词、AI 自动作曲、编曲、混音于一体

下载
  • 确认 config/broadcasting.phpdefault 已设为 pusher,且 connections.pusher.options.cluster 与 Pusher 控制台一致(如 us2
  • app/Providers/BroadcastServiceProvider.phpboot() 方法中,显式绑定用户解析逻辑:
    Broadcast::channel('chat.{roomId}', function ($user, $roomId) {
        return $user && $user->can('view', Room::findOrFail($roomId));
    });
  • 若使用 Sanctum,确保请求携带有效的 Authorization: Bearer {token},且该 token 已关联用户;web 中间件对广播鉴权无效,必须用 auth:sanctum

如何让 Reverb 替代 Pusher 实现零成本广播?

Reverb 是 Laravel 官方维护的高性能、纯 PHP 广播服务器,无需第三方服务,但需额外启动进程,且不兼容 Pusher 的客户端 SDK 兼容层(除非启用 pusher 兼容模式)。

  • 安装:
    composer require laravel/reverb
  • 发布配置:
    php artisan vendor:publish --provider="Laravel\Reverb\ReverbServiceProvider" --tag="reverb-config"
  • 启动服务:
    php artisan reverb:start
    ,并确保 BROADCAST_CONNECTION=reverb.env 中生效
  • 前端改用 Reverb 客户端:
    import { createClient } from 'laravel-reverb';
    
    const reverb = createClient({
        key: import.meta.env.VITE_REVERB_APP_KEY,
        wsHost: import.meta.env.VITE_REVERB_HOST,
        wsPort: import.meta.env.VITE_REVERB_PORT || 8080,
        wssPort: import.meta.env.VITE_REVERB_SSL_PORT || 443,
        forceTLS: (import.meta.env.VITE_REVERB_SCHEME || 'https') === 'https',
    });

真正麻烦的是跨域和 HTTPS 场景下的 WebSocket 连接:Reverb 默认只监听 localhost,生产环境必须配置 REVERB_HOST=your-domain.com 并反向代理 WebSocket 流量;Pusher 则天然规避此问题,但代价是费用和厂商锁定。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

319

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

277

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

371

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

374

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

85

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

65

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

68

2025.08.05

什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

178

2024.05.11

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

9

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 9.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号