Laravel如何与Pusher实现实时通信?(WebSocket示例)
发布时间 - 2025-12-22 00:00:00 点击率:次Laravel 配合 Pusher 实现实时通信本质是利用 Pusher 托管的 WebSocket 服务,通过 Laravel 广播机制将事件推送给 Pusher,前端用 Pusher JS SDK 或 Laravel Echo 订阅监听。
用 Laravel 配合 Pusher 实现实时通信,本质是借助 Pusher 托管的 WebSocket 服务,绕过自己搭建和维护 WebSocket 服务器的复杂性。Laravel 不直接处理 WebSocket 连接,而是通过事件广播机制把数据推给 Pusher,前端再通过 Pusher JS SDK 订阅频道、监听事件。
1. 安装依赖并配置广播驱动
先确保 Laravel 的广播功能已启用。修改 .env 文件,将广播驱动设为 PUSHER,并填入 Pusher 控制台获取的凭证:
BROADCAST_DRIVER=pusher PUSHER_APP_ID=your-app-id PUSHER_APP_KEY=your-app-key PUSHER_APP_SECRET=your-app-secret PUSHER_APP_CLUSTER=mt1 // 注意:不是 us2 或 eu,以控制台显示为准
安装官方 Pusher PHP SDK:
composer require pusher/pusher-php-server "^7.0"
2. 创建可广播的事件
运行命令生成事件类(比如通知用户新消息):
php artisan make:event NewMessagePosted
在生成的事件类中实现 ShouldBroadcast 接口,并定义 broadcastOn() 方法指定频道(如私有频道 private-chat.{roomId}),还可设置 broadcastWith() 控制发送的数据字段。
- 频道名需与前端订阅的一致,且注意权限:public(公开)、private(需服务端鉴权)、presence(带用户信息的私有频道)
- 事件类默认使用
App\Events命名空间,别忘了在EventServiceProvider中注册或使用自动发现
3. 后端触发广播
在控制器或业务逻辑中,直接 dispatch 该事件即可:
event(new NewMessagePosted($message, $roomId));// 或 NewMessagePosted::dispatch($message, $roomId);
Laravel 会自动调用 Pusher SDK,把序列化后的事件数据发到对应频道。不需要手动写推送逻辑。
4. 前端监听事件(WebSocket 示例)
在页面中引入 Pusher JS SDK,并用 Laravel 的 echo 封装库(推荐)或原生 SDK 订阅:
// 使用 Laravel Echo(需 npm install --save laravel-echo pusher-js)
import Echo from 'laravel-echo';
window.Pusher = require('pusher-js');
window.Echo = new Echo({
broadcaster: 'pusher',
key: 'your-app-key',
cluster: 'mt1',
encrypted: true,
authEndpoint: '/api/broadcasting/auth', // 私有/存在频道需要后端鉴权
});
// 监听私有频道上的事件
Echo.private(`chat.${roomId}`)
.listen('NewMessagePosted', (e) => {
console.log('收到新消息:', e.message);
// 更新 UI
});
- 若用 private 或 presence 频道,需在
routes/channels.php中定义授权逻辑(返回 true 或数组形式的用户数据) - 确保前端 key、cluster 和 .env 中完全一致,否则连接失败且无明显报错
- 开发时打开 Pusher Debug Console(控制台 → Demo Console)可实时看到事件是否成功发出和被接收
基本上就这些。不复杂但容易忽略细节,比如集群填错、频道名大小写不一致、没开鉴权路由,都会导致“前端收不到”。跑通一次后,增删频道和事件就是复制粘贴的事了。
# php
# laravel
# js
# 前端
# composer
# npm
# app
# websocket
# 后端
# 路由
# win
# echo
# 命名空间
# 封装
# 接口
# public
# private
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何获取上海专业网站定制建站电话?
如何解决hover在ie6中的兼容性问题
怎样使用JSON进行数据交换_它有什么限制
如何生成腾讯云建站专用兑换码?
移动端脚本框架Hammer.js
百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏
Thinkphp 中 distinct 的用法解析
Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】
软银砸40亿美元收购DigitalBridge 强化AI资料中心布局
浅谈javascript alert和confirm的美化
EditPlus中的正则表达式实战(5)
Swift中switch语句区间和元组模式匹配
如何快速登录WAP自助建站平台?
如何在云主机上快速搭建多站点网站?
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
如何在Windows服务器上快速搭建网站?
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
Java解压缩zip - 解压缩多个文件或文件夹实例
Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】
Laravel如何为API生成Swagger或OpenAPI文档
Laravel Admin后台管理框架推荐_Laravel快速开发后台工具
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法
如何撰写建站申请书?关键要点有哪些?
香港服务器部署网站为何提示未备案?
Laravel软删除怎么实现_Laravel Eloquent SoftDeletes功能使用教程
详解MySQL数据库的安装与密码配置
Laravel怎么在Controller之外的地方验证数据
lovemo网页版地址 lovemo官网手机登录
QQ浏览器网页版登录入口 个人中心在线进入
宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法
Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】
如何快速使用云服务器搭建个人网站?
如何用已有域名快速搭建网站?
如何在建站主机中优化服务器配置?
Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践
Laravel Seeder填充数据教程_Laravel模型工厂Factory使用
如何快速搭建高效香港服务器网站?
Python制作简易注册登录系统
如何在云服务器上快速搭建个人网站?
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
html文件怎么打开证书错误_https协议的html打开提示不安全【指南】
javascript日期怎么处理_如何格式化输出
北京网站制作公司哪家好一点,北京租房网站有哪些?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】
Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区
如何挑选高效建站主机与优质域名?
如何安全更换建站之星模板并保留数据?


// 或
NewMessagePosted::dispatch($message, $roomId);