我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Laravel如何快速创建简单事件流

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Laravel如何快速创建简单事件流

这篇文章主要介绍“Laravel如何快速创建简单事件流”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Laravel如何快速创建简单事件流”文章能帮助大家解决问题。

先决条件

在开始之前,你需要在机器上安装 Laravel。

我将在这个演示中使用 DigitalOcean Ubuntu Droplet 。如果你愿意,你可以使用我的会员代码获得免费 $100 DigitalOcean 积分来启动你自己的服务器

如果你还没有,可以按照本教程中的步骤进行操作:

  • How to Install Laravel on DigitalOcean with 1-Click

或者可以使用这个很棒的脚本进行安装:

  • LaraSail

创建一个 Controller

让我们从创建一个处理事件流的控制器开始。

使用以下命令:

php artisan make:controller EventStreamController

这将在 App\Http\Controllers 目录中创建一个新控制器。

添加事件流方法

一旦我们创建了我们的控制器,我们需要向它添加 stream 方法。 该方法将用于发送事件流。

打开 EventStreamController.php 文件并添加以下代码:

<?phpnamespace App\Http\Controllers;use Carbon\Carbon;use App\Models\Trade;class StreamsController extends Controller{        public function stream(){        return response()->stream(function () {            while (true) {                echo "event: ping\n";                $curDate = date(DATE_ISO8601);                echo 'data: {"time": "' . $curDate . '"}';                echo "\n\n";                $trades = Trade::latest()->get();                echo 'data: {"total_trades":' . $trades->count() . '}' . "\n\n";                $latestTrades = Trade::with('user', 'stock')->latest()->first();                if ($latestTrades) {                    echo 'data: {"latest_trade_user":"' . $latestTrades->user->name . '", "latest_trade_stock":"' . $latestTrades->stock->symbol . '", "latest_trade_volume":"' . $latestTrades->volume . '", "latest_trade_price":"' . $latestTrades->stock->price . '", "latest_trade_type":"' . $latestTrades->type . '"}' . "\n\n";                }                ob_flush();                flush();                // 如果客户端中止连接,则中断循环(关闭页面)                if (connection_aborted()) {break;}                usleep(50000); // 50ms            }        }, 200, [            'Cache-Control' => 'no-cache',            'Content-Type' => 'text/event-stream',        ]);    }}

这里要注意的主要事项是:

  • 我们使用 response()->stream() 方法来创建事件流。

  • 然后我们有一个无限循环,每隔50ms发送一次事件流。

  • 如果客户端中止连接,我们使用 ob_flush()flush() 来发送事件流。

  • 我们使用 sleep() 发送下一个事件之前等待50ms。

  • 我们使用 connection_aborted() 来中断循环,如果客户端中止了连接。

  • 我们使用 Carbon\Carbon 类获取当前日期。

  • 我们使用 App\Models\Trade 模型获取最新交易。这仅用于演示,你可以使用任何你想要的模型。

  • Content-Type 标头设置为 text/event-stream 以告知浏览器响应是事件流。

启用输出缓冲

为了使上述代码正常工作,我们需要在你的 PHP.ini 文件中启用输出缓冲。 这是通过将以下行添加到 php.ini 文件中完成的:

output_buffering = On

进行此更改后,可能需要重新加载 PHP-FPM 服务。 或者如果你使用的是 Apache,则可以重新启动 Apache。

添加路由

当请求 /stream 路由时,我们想调用 ``stream` 方法。

路由将被添加到routes/web.php 文件中,如下所示:

use App\Http\Controllers\StreamsController;Route::get('/stream', [StreamsController::class, 'stream']);

使用前端的事件流

你可以使用 Vue.js 之类的前端框架来处理事件流。 但是对于这个演示,我将使用纯 Javascript。

添加到 blade 模板中的 JavaScript 片段如下所示:

const eventSource = new EventSource('/stream');eventSource.onmessage = function(event) {    const data = JSON.parse(event.data);    if (data.time) {        document.getElementById('time').innerHTML = data.time;    }    const newElement = document.createElement("li");    const eventList = document.getElementById("list");    newElement.textContent = "message: " + event.data;    eventList.appendChild(newElement);}

SSE vs WebSockets

事件流很棒且易于使用,但与 WebSockets 等其他流协议相比,它也有一些优点和缺点。

例如,SSE 是单向的,这意味着一旦建立连接,服务器只会向客户端发送数据,而客户端不能将数据发送回服务器。

与长轮询不同,使用 WebSockets,你只有一个与服务器的连接,类似于 SSE(服务器发送事件)。 连接是双工的,这意味着你可以从服务器发送和接收数据。

关于“Laravel如何快速创建简单事件流”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Laravel如何快速创建简单事件流

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Laravel如何快速创建简单事件流

这篇文章主要介绍“Laravel如何快速创建简单事件流”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Laravel如何快速创建简单事件流”文章能帮助大家解决问题。先决条件在开始之前,你需要在机器上安
2023-07-04

Win8如何在桌面创建快捷方式(3种简单的方式)

很多网友在问Win8如何在桌面创建快捷方式,本次介绍3种简单的方式。下面小编就以联想的“联想远程软件服务”应用程序为例。告诉大家如何在在桌面创建快捷方式。1. 找到安装应用程序的安装路径,然后直接将应用程序的图标右击
2022-06-04

聊聊Angular中如何创建简单独立组件并使用

本篇文章带大家了解一下Angular中的独立组件,介绍一下如何创建简单的独立组件以及如何在 Angular 应用程序中使用它们,希望对大家有所帮助!
2023-05-14

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录