您好,登錄后才能下訂單哦!
這篇文章主要介紹“Laravel如何快速創建簡單事件流”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Laravel如何快速創建簡單事件流”文章能幫助大家解決問題。
在開始之前,你需要在機器上安裝 Laravel。
我將在這個演示中使用 DigitalOcean Ubuntu Droplet 。如果你愿意,你可以使用我的會員代碼獲得免費 $100 DigitalOcean 積分來啟動你自己的服務器!
如果你還沒有,可以按照本教程中的步驟進行操作:
How to Install Laravel on DigitalOcean with 1-Click
或者可以使用這個很棒的腳本進行安裝:
LaraSail
讓我們從創建一個處理事件流的控制器開始。
使用以下命令:
php artisan make:controller EventStreamController
這將在 App\Http\Controllers 目錄中創建一個新控制器。
一旦我們創建了我們的控制器,我們需要向它添加 stream
方法。 該方法將用于發送事件流。
打開 EventStreamController.php
文件并添加以下代碼:
<?php
namespace App\Http\Controllers;use Carbon\Carbon;use App\Models\Trade;class StreamsController extends Controller{
/**
* 事件流代碼
*
* @return \Illuminate\Http\Response
*/
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);}
事件流很棒且易于使用,但與 WebSockets 等其他流協議相比,它也有一些優點和缺點。
例如,SSE 是單向的,這意味著一旦建立連接,服務器只會向客戶端發送數據,而客戶端不能將數據發送回服務器。
與長輪詢不同,使用 WebSockets,你只有一個與服務器的連接,類似于 SSE(服務器發送事件)。 連接是雙工的,這意味著你可以從服務器發送和接收數據。
關于“Laravel如何快速創建簡單事件流”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。