简单16步搞定Laravel Echo的使用

简单16步搞定Laravel Echo的使用

先飚几句英文,说说 laravel echo 的作用:

One of my favorite projects in the Laravel ecosystem is Echo. Echo enables real-time web applications through the use of WebSockets and hooks directly into Laravel’s event broadcasting features. This means developers can use a familiar PHP API to send real-time data. A very common use-case for this type of functionality would be a notification or chat system.翻译「略」摘自:https://www.imarc.com/blog/realtime-notifications-with-laravel-echo-server-docker-and-traefik

官方文档推荐使用 Pusher 或者 laravel-echo-server (是一个使用 NodeJS + Socket.IO 实现的 WebSocket 服务端)。

推荐:laravel教程

在国内,个人还是不推荐使用 Pusher,访问速度有所影响,而且其还是一个商业产品。

今天利用最简便的「16」步,走一遍代码集成 laradock 和 laravel-echo-server 来使用 Laravel Echo。

搭建基础环境

// 1. new projectlaravel new echolearning// 2. 使用 laradockgit clone https://github.com/Laradock/laradock.git// 3. 创建 .envcp env-example .env// 4. 创建 containerdocker-compose up -d php-worker laravel-echo-server nginx redis

c6bbf4009a87c4aef48a01119e20199.png

// 5. 进入 workspace 容器docker-compose exec --user=laradock workspace bash// 6. 安装插件// 6.1 推荐使用 laravel-china 维护的 composer 国内镜像composer config -g repo.packagist composer https://packagist.laravel-china.org// 6.2 并行下载插件composer global require "hirak/prestissimo"// 6.3 配置 yarn 国内镜像yarn config set registry 'https://registry.npm.taobao.org'// 注:以上可以在 laradock 中配置// 6.4 执行安装composer installyarn install// 7. 创建 .env 和 keycp .env.example .envphp artisan key:generate

好了,我们开始在浏览器输入:http://localhost,网站跑起来了

8c3d6beef9cc1a433be3138f01f28f8.png

使用 Laravel Echo Server

因为 laradock 集成了「Laravel Echo Server」,所以我们很方便的使用到 Laravel Echo。

// 8. 配置广播驱动和 redis 服务器BROADCAST_DRIVER=redisREDIS_HOST=redis// 9. 安装 prediscomposer require predis/predis

准备好后端配置后,我们开始安装前端插件,毕竟 Laravel Echo 是前端工具。

// 10. 安装 socket.io-client laravel-echoyarn add socket.io-client laravel-echo

在 resources/assets/js/bootstrap.js 实例化 Echo:

// 11. 实例化 Echoimport Echo from 'laravel-echo'window.io = require('socket.io-client')window.Echo = new Echo({    broadcaster: 'socket.io',    host: window.location.hostname + ':6001'});// Laravel 官方推荐使用 pusher// 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,//     encrypted: true// });

接下来我们就可以使用 Echo 实例,监听后端发过来的广播或者通知了。

首先我们利用已经给的 ExampleComponent 改造下,创建 Echo 监听,等待数据的到来,然后再显示在页面上。代码简单:

    
Example Component
  • {{ name }}
export default { data () { return { names: [] } }, mounted() { let that = this // 12. 创建 Echo 监听 Echo.channel('rss') .listen('RssCreatedEvent', (e) => { that.names.push(e.name) }); } }

我们在后端添加一个 rss 被创建的事件 RssCreatedEvent,并继承 ShouldBroadcast。

// 13. 创建 RssCreatedEvent 事件php artisan make:event RssCreatedEvent

我们使用假数据,让它返回当前的时间,方便查看效果:

 Carbon::now()->toDateTimeString()];    }}

然后我们就可以做一个定时任务了,让它每隔一分钟,广播一次:

简单AI 简单AI

搜狐推出的AI图片生成社区

简单AI 307 查看详情 简单AI

protected function schedule(Schedule $schedule){    // 15. 每隔一分钟执行一次    $schedule->call(function () {        event(new RssCreatedEvent());    })->everyMinute();}

最后让首页加载 vue 组件,刷新测试:

getLocale() }}">                                            Laravel            

注:需要在 header 引入


编译前端:

// 16. 运行 watchyarn run watch-poll

刷新网页,查看运行效果:

38ca55b8ef7d0f989dea50580d4d146.png

如我们所愿,每隔一分钟,广播一次,前端 laravel-echo 监听并捕获该广播,然后读取数据,展示出来。

总结

到目前为止,我们用到的技术都有:

1.laradock 的使用

2.laravel echo server 的使用

3.广播事件

4.event() 辅助函数

5.$schedule 定时任务

6.Laravel Echo 的使用

我们基本可以使用 Laravel Echo 了,至于更深入的使用,推荐查看官网文档。

最后再一次强烈推荐大家用 laradock 来部署 Docker 开发环境,因为你想要用到的工具和环境,相信 laradock 都为你准备好了。

以上就是简单16步搞定Laravel Echo的使用的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/491993.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 16:11:03
下一篇 2025年11月8日 16:11:50

相关推荐

  • PHP中的微服务架构:如何在PHP中构建微服务应用

    php可以构建稳定高效的微服务架构,关键在于理解核心理念并合理使用工具。其优势包括成熟框架(如laravel、symfony)、易部署维护及丰富社区资源。拆分服务应按业务功能(如订单、用户、支付服务)、数据边界或团队协作模式进行,初期保持2~5个服务为宜,并避免循环依赖。服务间通信可采用同步调用(r…

    2025年12月10日
    000
  • PHP中的CORS处理:如何解决跨域资源共享问题

    cors是浏览器安全机制,限制不同源间的http请求,php解决跨域需设置响应头并处理options预检。具体步骤包括:1.添加access-control-allow-origin指定允许的源;2.使用access-control-allow-methods设置允许的请求方法;3.通过access…

    2025年12月10日
    000
  • PHP中的身份验证:如何在PHP中实现用户身份验证

    用户身份验证在php开发中至关重要,其核心流程分为四步:用户提交信息、系统查询数据库、密码比对、创建session;密码必须用password_hash()加密存储,并用password_verify()验证;使用session维护登录状态时应设置$_session标识,并在登出时清除;安全方面需防…

    2025年12月10日
    000
  • PHP中的命名空间:如何组织代码避免命名冲突

    命名空间是php中用于组织代码、避免类名或函数名冲突的工具,通过给类、函数和常量添加“前缀”实现独立作用域。例如,adminuser 和 frontenduser 可区分同名类;定义命名空间只需在文件顶部使用 namespace 关键字,如 namespace appcontroller;;引用类可…

    2025年12月10日
    000
  • PHP中的事件驱动:如何在PHP中实现事件驱动编程

    事件驱动编程是一种以“事件”为中心的编程范式,程序执行流程由外部事件决定。在php中实现事件驱动的核心在于通过事件监听和触发机制解耦代码逻辑,提高系统的可扩展性和可维护性。具体实现方式有两种:1. 使用观察者模式手动实现,通过自定义eventdispatcher类绑定事件与回调函数并在适当时机触发;…

    2025年12月10日
    000
  • PHP中的服务监控:如何监控PHP应用的运行状态

    要对php应用进行有效监控,首先应建立健康检查接口以确认服务可用性,其次关注性能指标如执行时间和资源消耗,同时监控错误日志以捕捉致命错误和警告,并对第三方依赖进行健康检查。1. 建议创建轻量的健康检查接口,返回状态码或json结构,并通过外部工具定期访问,触发异常报警;2. 通过记录请求耗时和内存使…

    2025年12月10日
    000
  • PHP中的中间件:如何在PHP中实现中间件模式

    中间件在php开发中是一种处理请求和响应的流程插件,其核心在于构建可串联、可复用的请求处理链。手动实现中间件机制可以通过定义一个中间件队列,并依次调用每个中间件,传入下一个中间件作为参数,例如通过middlewarerunner类来add添加中间件并run执行处理流程。在框架中使用中间件更为便捷,l…

    2025年12月10日
    000
  • PHP中的匿名函数:如何在PHP中使用闭包和匿名函数

    匿名函数是php中没有名字的函数,常用于回调或作为参数传递,闭包则是其实现方式,能捕获外部变量。1. 匿名函数可在使用时直接定义,如:$greet = function($name) { echo “hello, $name!”;}; 2. 闭包通过use引入外部变量,如:$…

    2025年12月10日
    000
  • PHP中的路由系统:如何在PHP中实现URL路由功能

    url路由是将url路径映射到具体处理程序的技术。其核心作用是根据用户访问的url,将请求分发到对应的控制器或处理函数,从而展示相应内容。手动实现基础路由可通过获取请求路径、定义路由规则、匹配路径并调用对应处理文件完成。支持动态路由与参数捕获需使用正则表达式匹配路径并提取参数,例如通过preg_ma…

    2025年12月10日
    000
  • PHP中的API开发:如何在PHP中开发RESTful API

    使用php构建restful api需掌握http方法、路由设计和数据处理。1. 理解restful api基本概念,采用get、post、put、delete等方法操作资源,并用语义化url路径表示资源。2. 推荐使用框架开发,如laravel、slim或symfony,提升效率与结构清晰度。3.…

    2025年12月10日
    000
  • PHP中的框架比较:如何选择适合的PHP框架开发项目

    选框架看三点:项目需求、团队熟悉度、长期维护性。1. laravel 功能全生态强,适合中大型项目,如电商平台、后台系统,自带数据库迁移、队列任务等功能,开发效率高但相对较重;2. symfony 组件化设计,适合定制化开发,适合企业级应用,自由度高且支持依赖注入,但上手难度高、配置繁琐;3. co…

    2025年12月10日
    000
  • PHP中的模板引擎:如何在PHP中使用模板引擎渲染页面

    使用模板引擎是因为它能分离业务逻辑与页面展示,提升代码可维护性和团队协作效率。模板引擎允许前端专注html/css/js,后端专注数据和逻辑,尤其适用于项目规模扩大后的开发需求。常见的php模板引擎有smarty、twig、blade等,它们均支持变量输出、条件判断、循环结构和模板继承。选择模板引擎…

    2025年12月10日
    000
  • PHP中的依赖管理:如何在PHP中使用Composer管理依赖

    composer是php中用于依赖管理的工具,它通过composer.json文件声明项目所需包并自动下载加载。安装时运行命令获取composer.phar文件并全局移动,初始化时用composer init创建配置文件。使用时通过composer require添加依赖如guzzlehttp/gu…

    2025年12月10日
    000
  • PHP中的依赖注入:如何在PHP中实现依赖注入模式

    依赖注入是一种设计模式,通过外部传入依赖对象实现解耦。其核心在于不自行创建依赖,而是由外部提供,从而提升代码灵活性与可测试性。在php中,可通过构造函数注入、方法注入或setter注入实现,其中构造函数适用于必需依赖,setter适合可选依赖。现代框架如laravel内置依赖注入容器,能自动解析并实…

    2025年12月10日
    000
  • PHP中的日志记录:如何在PHP中记录和管理日志信息

    php中记录和管理日志的实用方法包括:1. 使用error_log函数记录基本日志,适合小型项目或临时调试,但不便于集中管理;2. 使用monolog库进行高级日志管理,支持按级别分类、多目的地输出,适合中大型项目;3. 将日志集中化,通过elk stack、graylog、sentry等工具实现统…

    2025年12月10日
    000
  • PHP中的速率限制:如何实现API请求频率控制

    在php中实现api速率限制有三种主要方法。第一,使用redis做计数器,通过incr命令递增访问次数并配合expire设置过期时间,以ip为key记录访问频率,适合中等规模场景;第二,基于令牌桶算法的限流策略,系统按固定速率生成令牌,请求需消耗令牌,适合应对突发流量和大型系统;第三,结合中间件或框…

    2025年12月10日
    000
  • php方法连续调用的技巧

    在php面向对象编程中,实现方法的连续调用(链式调用)的关键是每个方法返回当前对象本身,即return $this。1. 返回$this是实现链式调用的基础,通过在方法中使用return $this,使后续方法能继续在该对象上操作,例如setname()和setage()方法均返回$this以支持连…

    2025年12月10日
    000
  • php开发是做什么的 php开发的主要工作内容和应用场景

    php开发是利用php语言进行网站和网络应用的开发工作。具体包括:1) 编写和维护php代码,2) 设计数据库结构,3) 优化网站性能,4) 与前端开发人员和设计师合作,确保产品质量和用户体验。 PHP开发是做什么的?简单来说,PHP开发就是利用PHP语言进行网站和网络应用的开发工作。PHP是一种广…

    2025年12月10日
    000
  • php如何操作jsonp?php跨域请求的解决方案?

    jsonp 是一种利用 标签实现跨域请求的技术,其核心在于服务端返回 javascript 脚本调用前端指定的回调函数并传递数据。1. 前端请求需携带 callback 参数;2. 服务端接收该参数并包裹在 json 数据外输出;3. 需设置响应头为 application/javascript;4…

    2025年12月10日
    000
  • php如何实现数据导入?php导入excel数据的库

    在 php 中实现 excel 数据导入推荐使用 phpspreadsheet、laravel-excel 或 spout。一、phpspreadsheet 是功能全面的原生库,支持多种格式,通过 iofactory::load() 读取文件并转为数组处理;注意大文件需优化内存。二、laravel …

    2025年12月10日
    000

发表回复

登录后才能评论
关注微信