目录
前言
尽量缩小实验的对象的规模,找步骤少的教程
将任务分解得可以获得子任务成功的反馈
多打 Log
对被实验的对象尽量熟悉起来
多综合各方信息,特别是那些成功的
如果搜错误提示没有用的东西或者搜索结果太多就看看代码
就算成功了也不要高兴得太早,多练习几遍
尽量选择更新的教程
面向搜索引擎编程
本体
创建项目
配置数据库信息
安装服务器端包 beyondcode/laravel-websockets
安装 pusher
配置 Laravel WebSockets
创建事件
安装客户端包 laravel-echo
结语
首页 php框架 Laravel 教你用laravel-websockets搞个“低配”广播系统

教你用laravel-websockets搞个“低配”广播系统

Jan 05, 2023 pm 04:28 PM
laravel

本篇文章给大家带来了关于Laravel的相关知识,其中主要介绍了怎么用laravel-websockets来实现一个“低配版”广播系统,感兴趣的朋友一起来看一下吧,希望对大家有帮助。

教你用laravel-websockets搞个“低配”广播系统

前言

网上找了好几个教程都没成功,然后死磕一个教程不断研究最终成功了。然后就写了这篇教程,希望能帮到跟我一样笨的人。另外希望不要误导到读者。希望读者最好不要过于信任我的这个教程。我其实是稀里糊涂地成功的,我的这个教程可能也有坑。还有一点是我觉得我研究的过程好像收获挺大的,如果时间充裕的话建议自己研究。

教程的开头我先大致介绍一下我是怎么搞出这个教程介绍的方法的。我建议看教程的人重视一下这部分,因为我怀疑 Laravel 或者相关的库一更新可能又会出现不兼容或者错乱的情况,然后就又有问题了。到时候可能就需要读者自行研究了。

为什么说是大致介绍呢,因为很多地方我感觉都是我瞎猫碰死耗子蒙出来的。另外可能需要一些无法言说的经验吧。

尽量缩小实验的对象的规模,找步骤少的教程

刚开始我是照着官方文档中文版做的,后来发现这个实在是太复杂了,可能错一步就会失败。而且有的时候连错误提示也没有,就算有错误提示不是搜不到就是有太多回答完全不一样的问题。如果尽量缩小规模的话,应该就能尽量少踩点坑了。

将任务分解得可以获得子任务成功的反馈

刚开始我是一步一步跟着做,然后最后看是否成功,后来发现这种方法太低效了。然后我发现某些子步骤是可以通过一些方法判断是否成功的,比如 laravel-websockets 安装成功之后能打开那个 dashboard。就是 /laravel-websockets 。另外还有发送广播的代码如果成功了的话可以在前面说的那个 dashboard 里看到效果。最后就是全部成功就能在浏览器里看到效果了。所以后来我如果当前阶段没有成功就不会继续做下去了,继续研究本阶段哪里错了。

多打 Log

我是通过打 Log 发现客户端的 Echo 根本没有初始化成功的,因为少个参数。之前好像也有个错误提示,但是我好像没看懂。通过在初始化 Echo 的前后分别输出两条不一样的 Log,我发现只有前一条执行了,后一条根本没执行,所以得出了程序遇到错误就停止执行了的结论。

对被实验的对象尽量熟悉起来

比如我没搜索到某条报错的相关信息。但是后来发现里面的某个词在配置里出现过,改了一下那个配置就好了。就是这个:“Uncaught Options object must provide a cluster”。不过后来我在网上发现个跟我一样的方法,没准我之前看过那个方法,可能是因为楼主说没用所以我就没试。

多综合各方信息,特别是那些成功的

虽然不一定能拿来就用,甚至可能会产生误导,但是我相信信息多一些还是更有助于解决问题的。比如我就在哔哩哔哩上搜过“laravel 广播”看过几个视频。还搜索了一些非官方文档的教程。

如果搜错误提示没有用的东西或者搜索结果太多就看看代码

不过我感觉这条有用的概率不大,实在没招了再用吧。我是通过这个方法发现我在取消注释代码的时候少取消注释了一行,然后出现了很奇怪的错误提示。

就算成功了也不要高兴得太早,多练习几遍

步骤越多越容易出问题,这个广播系统的步骤是真多。多练习也能多熟悉一点。

尽量选择更新的教程

我一般在搜索引擎里加个一年内的条件。

面向搜索引擎编程

感觉这次大概有一半以上的问题都是通过搜索引擎解决的吧,完全自己解决的部分好像很少。

本体

我这个教程某些方面比较啰嗦,是从创建项目开始的,另外还提到了配置数据库。水平比较高的读者可以忽略一些内容。至于高端的读者应该用不着看我的这种东西。不过我对命令的介绍基本没有,有需求建议去看下面的英文文章。
备忘

我这个是公共频道的。还有队列用的是默认的 sync,据说只能用于开发环境。总之我这个教程应该是挺残废的,但是跑通了应该就可以以此为起点根据官方文档实验新的配置和添加新的功能了。

我的这个教程主要参考自这篇文章:How to use Laravel WebSockets

创建项目

在 Apache24\htdocs 或者类似的地方运行下面的命令:

composer create-project laravel/laravel bc
登录后复制

在项目路径中运行以下命令:

php artisan serve
登录后复制

注意运行完上面的命令当前命令行窗口一般就不能运行命令了,需要重启一个命令行窗口。想要在继续在当前命令行窗口运行命令除非配合后台运行的命令。

配置数据库信息

在配置数据库之前需要创建一个数据库,我用的是 test。不过就算不创建在 migrate 的时候也会提示创建。这个差点就忘了,因为之前一直没有删除这个数据库。

.env

DB_CONNECTION=mysqlDB_HOST=127.0.0.1DB_PORT=3306DB_DATABASE=testDB_USERNAME=rootDB_PASSWORD=1234
登录后复制

注意要填你的数据库的实际的信息,别照抄我的配置。

安装服务器端包 beyondcode/laravel-websockets

在项目路径中运行以下命令:

composer require beyondcode/laravel-websockets
php artisan vendor:publish --provider="BeyondCode\LaravelWebSockets\WebSocketsServiceProvider" --tag="migrations"php artisan migrate
php artisan vendor:publish --provider="BeyondCode\LaravelWebSockets\WebSocketsServiceProvider" --tag="config"
登录后复制

安装 pusher

在项目路径中运行以下命令:

composer require pusher/pusher-php-server
登录后复制

注意这条我跟我参考的那篇文章不一样,我这个安装的应该是最新版的。原文好像指定版本了。

配置 Laravel WebSockets

.env

BROADCAST_DRIVER=pusherPUSHER_APP_ID=12345PUSHER_APP_KEY=ABCDEFGPUSHER_APP_SECRET=HIJKLMNOPPUSHER_HOST=127.0.0.1PUSHER_PORT=6001PUSHER_SCHEME=httpPUSHER_APP_CLUSTER=mt1
登录后复制

注意这里跟我参考的那篇英文文章也不一样,我强迫症,感觉改 .env 更优雅一些。毕竟其他地方都会优先读 .env。感觉 .env 更像是函数,一个地方改动了不用修改所有调用的地方。感觉前一句有点问题,大概就是那个意思吧。

再注意一下第二条到第四条的值是随便填的。

运行 Laravel WebSockets 服务器

在项目路径中运行以下命令:

php artisan websockets:serve
登录后复制

这个也是运行之后当前命令行窗口就不能输入命令了。【推荐学习:laravel视频教程

之后在浏览器地址栏输入 127.0.0.1:8000/laravel-websockets 就能看前面的操作是否成功了。如果你不是通过“php artisan serve”运行的服务器的话可能端口会不一样。点击那个 Connect 按钮如果在 Events 下面出现一些东西应该就是阶段性成功了。注意这个网页在没那个啥的情况下打开是非常慢的,至少在我这里很慢。因为里面有个 js 库的下载速度很慢。注意下面的改 blade 模板的行为是可选的!另外我不知道下面的那个 cdn 有没有问题,毕竟好像不是大厂的 cdn。如果你嫌慢又不想那个啥的话可以将 vendor\beyondcode\laravel-websockets\resources\views\dashboard.blade.php 中的

<script  src="https://www.php.cn/link/19e0c9edc141240b5de750fa83ba1bed"></script>
登录后复制

换成

<script  src="https://cdn.bootcdn.net/ajax/libs/plotly.js/2.17.0/plotly.min.js"></script>
登录后复制

我是通过用 VS Code 搜索功能直接搜索 cdn.plot.ly/plotly-latest.min.js 搜出来这个文件的。另外是在火狐的开发者工具的网络中发现这个 js 库加载速度慢的。另外这种直接改这种地方的文件应该是不太优雅。

创建事件

在项目路径中运行以下命令:

php artisan make:event NewTrade
登录后复制

app\Events\NewTrade.php

<?php
namespace App\Events;use Illuminate\Broadcasting\Channel;
use Illuminate\Broadcasting\InteractsWithSockets;
use Illuminate\Broadcasting\PresenceChannel;
use Illuminate\Broadcasting\PrivateChannel;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;use Illuminate\Foundation\Events\Dispatchable;
use Illuminate\Queue\SerializesModels;
class NewTrade implements ShouldBroadcast{
    use Dispatchable, InteractsWithSockets, SerializesModels;

    public $trade;

    /**
     * Create a new event instance.
     *
     * @return void
     */
    public function __construct($trade)
    {
        $this->trade = $trade;
    }

    /**
     * Get the channels the event should broadcast on.
     *
     * @return \Illuminate\Broadcasting\Channel|array
     */
    public function broadcastOn()
    {
        return new Channel('trades');
    }}
登录后复制

在项目路径中运行以下命令:

php artisan tinker
登录后复制

运行这条命令后会启动 Laravel 的交互式解释器,我理解就是输入一些语句可以直接执行。另外还有一些其他的实用的命令。这个也是运行之后当前命令行窗口就不能输入正常的系统命令了,但是这个命令行窗口之后要输入 php 语句。顺便说一下,VS Code 里的终端在 tinker 里没法 Ctrl + V,但是右键是粘贴的功能。

然后在上面的执行过 php artisan tinker 的那个命令行窗口运行以下命令:

event (new \App\Events\NewTrade('test'))
登录后复制
登录后复制

之后就能在上面提到的那个 127.0.0.1:8000/laravel-websockets 页面看到发出的消息了。能看到的话就说明阶段性成功了。

安装客户端包 laravel-echo

在项目路径中运行以下命令:

npm installnpm install --save-dev laravel-echo pusher-js
登录后复制

resources\js\bootstrap.js

import Echo from 'laravel-echo';import Pusher from 'pusher-js';window.Pusher = Pusher;window.Echo = new Echo({
    broadcaster: 'pusher',
    key: import.meta.env.VITE_PUSHER_APP_KEY,
    wsHost: import.meta.env.VITE_PUSHER_HOST ? import.meta.env.VITE_PUSHER_HOST : `ws-${import.meta.env.VITE_PUSHER_APP_CLUSTER}.pusher.com`,
    wsPort: import.meta.env.VITE_PUSHER_PORT ?? 80,
    wssPort: import.meta.env.VITE_PUSHER_PORT ?? 443,
    forceTLS: (import.meta.env.VITE_PUSHER_SCHEME ?? 'https') === 'https',
    enabledTransports: ['ws', 'wss'],
    cluster: import.meta.env.VITE_PUSHER_APP_CLUSTER,});
登录后复制

注意这里也跟我参考的那篇英文文章不一样。我只是取消注释了那个文件中的那些东西,并在结尾添加了一行“cluster: import.meta.env.VITE_PUSHER_APP_CLUSTER,”。

在项目路径中运行以下命令:

npm run dev
登录后复制

这个也是运行之后当前命令行窗口就不能输入命令了。

添加客户端脚本

在文件
resources\views\welcome.blade.php
的 head 标签的结尾添加以下代码:

        @vite('resources/js/app.js')        <script>
            window.onload = function(){
                Echo.channel('trades')
                .listen('NewTrade', (e) => {
                    console.log(e.trade);
                });
            };
        </script>
    </head>
登录后复制

注意这里也跟我参考的那篇英文文章不一样。改了两处,一个是导入 app.js 的方法换了。另外套了一层 window.onload。

然后在浏览器的地址栏输入 127.0.0.1:8000/ 启动开发者工具并切换到控制台标签页。然后再在前面运行过 php artisan tinker 的那个命令行窗口中执行以下命令:

event (new \App\Events\NewTrade('test'))
登录后复制
登录后复制

最后切换到前面提到的开发者工具中的控制台标签页,应该能看到一条“test”消息。能看到就说明最终成功了。

结语

我只是个菜狗,不要问我太复杂的问题。我从开始搞这个广播系统到最终成功好像用了两三天的时间,就凭这个时间你应该就能体会到我有多菜了。

最后因为我是菜狗,所以可能会有一些理解上的错误,欢迎指出来。不过按照我的这个教程做基本上应该是会成功的。我做完这个教程自己照着又做了两遍,没问题。不过也可能会因为我没注意到一些东西,或者读者的环境跟我的不一样导致读者不成功。所以我也不敢保证。感觉早晚会失效,失效了如果我没更新的话谁看到了就回复一下提醒一下别人吧。

原文地址:https://learnku.com/articles/74366

以上是教你用laravel-websockets搞个“低配”广播系统的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1668
14
CakePHP 教程
1427
52
Laravel 教程
1329
25
PHP教程
1273
29
C# 教程
1256
24
laravel入门实例 laravel入门实例 Apr 18, 2025 pm 12:45 PM

Laravel 是一款 PHP 框架,用于轻松构建 Web 应用程序。它提供一系列强大的功能,包括:安装: 使用 Composer 全局安装 Laravel CLI,并在项目目录中创建应用程序。路由: 在 routes/web.php 中定义 URL 和处理函数之间的关系。视图: 在 resources/views 中创建视图以呈现应用程序的界面。数据库集成: 提供与 MySQL 等数据库的开箱即用集成,并使用迁移来创建和修改表。模型和控制器: 模型表示数据库实体,控制器处理 HTTP 请求。

解决 Craft CMS 中的缓存问题:使用 wiejeben/craft-laravel-mix 插件 解决 Craft CMS 中的缓存问题:使用 wiejeben/craft-laravel-mix 插件 Apr 18, 2025 am 09:24 AM

在使用CraftCMS开发网站时,常常会遇到资源文件缓存的问题,特别是当你频繁更新CSS和JavaScript文件时,旧版本的文件可能仍然被浏览器缓存,导致用户无法及时看到最新的更改。这个问题不仅影响用户体验,还会增加开发和调试的难度。最近,我在项目中遇到了类似的困扰,经过一番探索,我找到了wiejeben/craft-laravel-mix这个插件,它完美地解决了我的缓存问题。

Laravel如何学习 怎么免费学习Laravel Laravel如何学习 怎么免费学习Laravel Apr 18, 2025 pm 12:51 PM

想要学习 Laravel 框架,但苦于没有资源或经济压力?本文为你提供了免费学习 Laravel 的途径,教你如何利用网络平台、文档和社区论坛等资源,从入门到掌握,为你的 PHP 开发之旅奠定坚实基础。

laravel用户登录功能 laravel用户登录功能 Apr 18, 2025 pm 12:48 PM

Laravel 提供了一个全面的 Auth 框架,用于实现用户登录功能,包括:定义用户模型(Eloquent 模型)创建登录表单(Blade 模板引擎)编写登录控制器(继承 Auth\LoginController)验证登录请求(Auth::attempt)登录成功后重定向(redirect)考虑安全因素:哈希密码、防 CSRF 保护、速率限制和安全标头。此外,Auth 框架还提供重置密码、注册和验证电子邮件等功能。详情请参阅 Laravel 文档:https://laravel.com/doc

laravel框架安装方法 laravel框架安装方法 Apr 18, 2025 pm 12:54 PM

文章摘要:本文提供了详细分步说明,指导读者如何轻松安装 Laravel 框架。Laravel 是一个功能强大的 PHP 框架,它 упростил 和加快了 web 应用程序的开发过程。本教程涵盖了从系统要求到配置数据库和设置路由等各个方面的安装过程。通过遵循这些步骤,读者可以快速高效地为他们的 Laravel 项目打下坚实的基础。

laravel有哪些版本 laravel新手版本选择方法 laravel有哪些版本 laravel新手版本选择方法 Apr 18, 2025 pm 01:03 PM

在面向初学者的 Laravel 框架版本选择指南中,本文深入探讨了 Laravel 的版本差异,旨在协助初学者在众多版本之间做出明智的选择。我们将重点介绍每个版本的关键特征、比较它们的优缺点,并提供有用的建议,帮助新手根据他们的技能水准和项目需求挑选最合适的 Laravel 版本。对于初学者来说,选择一个合适的 Laravel 版本至关重要,因为它可以显著影响他们的学习曲线和整体开发体验。

laravel怎么查看版本号 laravel查看版本号方法 laravel怎么查看版本号 laravel查看版本号方法 Apr 18, 2025 pm 01:00 PM

Laravel框架内置了多种方法来方便地查看其版本号,满足开发者的不同需求。本文将探讨这些方法,包括使用Composer命令行工具、访问.env文件或通过PHP代码获取版本信息。这些方法对于维护和管理Laravel应用程序的版本控制至关重要。

laravel和thinkphp的区别 laravel和thinkphp的区别 Apr 18, 2025 pm 01:09 PM

Laravel 和 ThinkPHP 都是流行的 PHP 框架,在开发中各有优缺点。本文将深入比较这两者,重点介绍它们的架构、特性和性能差异,以帮助开发者根据其特定项目需求做出明智的选择。

See all articles