Server-Sent Events (SSE) は、アプリケーションでリアルタイムの通知や更新を有効にするための優れたソリューションです。 WebSocket とは異なり、SSE ではサーバーからクライアントへの一方向通信が可能であるため、軽量で実装が簡単です。このチュートリアルでは、Laravel バックエンドで SSE をセットアップし、Vue.js フロントエンドでイベントを使用する方法を説明します。
概要
SSE を使用して、シンプルなリアルタイム通知システムを作成します。認証されたユーザーに新しい通知があるたびに、サーバー (Laravel) はクライアント (Vue.js) に通知をプッシュします。ここで取り上げる内容の内訳は次のとおりです:
- バックエンド (Laravel): 通知をストリーミングするための SSE エンドポイントを設定します。
- フロントエンド (Vue.js): 受信通知をリッスンするために EventSource を設定します。
ステップ 1: バックエンド (Laravel)
1.1 Laravel で SSE ルートを作成する
routes/api.php で、SSE ストリームのエンドポイントを作成します。これにより、Vue.js フロントエンドが SSE 接続を確立し、通知をリッスンできるようになります。
AppHttpControllersNotificationController を使用します;
Route::get('/notifications', [NotificationController::class, 'get']);
1.2 ストリーミング通知のコントローラー メソッド
次に、NotificationController で、データベースから未読の通知を取得し、SSE 経由でクライアントにストリーミングするロジックを実装します。
namespace App\Http\Controllers; use App\Models\Notification; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; class NotificationController extends Controller { public function get(Request $request) { $headers = [ "Content-Type" => "text/event-stream", "Cache-Control" => "no-cache", "Connection" => "keep-alive", "X-Accel-Buffering" => "no", ]; return response()->stream(function () { while (true) { // Fetch the unread notifications for the authenticated user $notifications = Notification::where('clicked', 0) ->where('user_id', 2) // For now, hardcoding the user ID, you can replace it with Auth::id() for dynamic user handling ->get(); // If there are notifications, send them to the frontend if ($notifications->isNotEmpty()) { // Format notifications as JSON and send them via SSE echo "data: " . json_encode($notifications) . "\n\n"; } // Flush the output buffer ob_flush(); flush(); // Sleep for a few seconds before checking again sleep(5); } }, 200, $headers); } }
説明:
ストリーミング レスポンス: response()->stream() メソッドは、イベントの無限ストリームを送信するために使用されます。
通知: 特定のユーザーの未読通知 (クリック = 0) について通知モデルをクエリしています。通知は JSON としてエンコードされ、クライアントに送信されます。
ヘッダー: ヘッダーは SSE 用に設定されます (Content-Type: text/event-stream)。
無限ループ: while (true) ループは接続を開いたままにし、5 秒ごとに新しい通知を継続的に送信します (sleep(5) を変更することで調整可能)。
ステップ 2: フロントエンド (Vue.js)
次に、EventSource API を使用してこれらの通知をリッスンするように Vue.js フロントエンドを設定しましょう。
2.1. SSE イベントをリッスンするように Vue コンポーネントをセットアップする
SSE ストリームからの受信イベントをリッスンする Vue コンポーネントを作成します。
<template> <div> <h3 id="Unread-Notifications">Unread Notifications</h3> <ul v-if="notifications.length"> <li v-for="notification in notifications" :key="notification.id"> {{ notification.message }} </li> </ul> <p v-else>No new notifications</p> </div> </template> <script> export default { data() { return { notifications: [], // Store notifications }; }, mounted() { // Initialize EventSource to listen to the /api/notifications endpoint const eventSource = new EventSource('/api/notifications'); // Handle incoming events from SSE eventSource.onmessage = (event) => { const data = JSON.parse(event.data); // Parse JSON data from the server this.notifications = data; // Update notifications list }; // Handle errors eventSource.onerror = (error) => { console.error("EventSource failed:", error); eventSource.close(); // Close the connection if there's an error }; }, beforeDestroy() { // Close the SSE connection when the component is destroyed if (this.eventSource) { this.eventSource.close(); } } }; </script>
説明:
- EventSource: /api/notifications エンドポイントをリッスンする EventSource インスタンスを作成します。これにより、サーバーへの永続的な接続が確立されます。 onmessage: このイベント リスナーは受信メッセージを処理します。データは JSON から解析され、通知配列に追加されます。 onerror: エラーが発生した場合 (SSE 接続が失われた場合など)、エラーをログに記録し、接続を閉じます。
- beforeDestroy: メモリ リークを防ぐため、コンポーネントが破棄されると SSE 接続が閉じられます。
結論
このチュートリアルでは、Laravel バックエンドと Vue.js フロントエンドで Server-Sent Events (SSE) を使用してリアルタイム通知を設定しました。 SSE は、リアルタイムの更新をクライアントにプッシュするためのシンプルかつ効率的な方法を提供するため、通知などの機能に最適です。最小限のセットアップで、ライブのリアルタイム機能でアプリケーションを強化できます。
以上がLaravel および Vue.js のサーバー送信イベント (SSE) によるリアルタイム通知の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

JavaScriptフレームワークのパワーは、開発を簡素化し、ユーザーエクスペリエンスとアプリケーションのパフォーマンスを向上させることにあります。フレームワークを選択するときは、次のことを検討してください。1。プロジェクトのサイズと複雑さ、2。チームエクスペリエンス、3。エコシステムとコミュニティサポート。

はじめに私はあなたがそれを奇妙に思うかもしれないことを知っています、JavaScript、C、およびブラウザは正確に何をしなければなりませんか?彼らは無関係であるように見えますが、実際、彼らは現代のウェブ開発において非常に重要な役割を果たしています。今日は、これら3つの間の密接なつながりについて説明します。この記事を通して、JavaScriptがブラウザでどのように実行されるか、ブラウザエンジンでのCの役割、およびそれらが協力してWebページのレンダリングと相互作用を駆動する方法を学びます。私たちは皆、JavaScriptとブラウザの関係を知っています。 JavaScriptは、フロントエンド開発のコア言語です。ブラウザで直接実行され、Webページが鮮明で興味深いものになります。なぜJavascrを疑問に思ったことがありますか

node.jsは、主にストリームのおかげで、効率的なI/Oで優れています。 ストリームはデータを段階的に処理し、メモリの過負荷を回避します。大きなファイル、ネットワークタスク、リアルタイムアプリケーションの場合。ストリームとTypeScriptのタイプの安全性を組み合わせることで、パワーが作成されます

PythonとJavaScriptのパフォーマンスと効率の違いは、主に以下に反映されています。1)解釈された言語として、Pythonはゆっくりと実行されますが、開発効率が高く、迅速なプロトタイプ開発に適しています。 2)JavaScriptはブラウザ内の単一のスレッドに限定されていますが、マルチスレッドおよび非同期I/Oを使用してnode.jsのパフォーマンスを改善でき、両方とも実際のプロジェクトで利点があります。

JavaScriptは1995年に発信され、Brandon Ikeによって作成され、言語をCに実現しました。 2。JavaScriptのメモリ管理とパフォーマンスの最適化は、C言語に依存しています。 3. C言語のクロスプラットフォーム機能は、さまざまなオペレーティングシステムでJavaScriptを効率的に実行するのに役立ちます。

JavaScriptはブラウザとnode.js環境で実行され、JavaScriptエンジンに依存してコードを解析および実行します。 1)解析段階で抽象的構文ツリー(AST)を生成します。 2)ASTをコンパイル段階のバイトコードまたはマシンコードに変換します。 3)実行段階でコンパイルされたコードを実行します。

PythonとJavaScriptの将来の傾向には、1。Pythonが科学コンピューティングの分野での位置を統合し、AI、2。JavaScriptはWebテクノロジーの開発を促進します。どちらもそれぞれのフィールドでアプリケーションシナリオを拡大し続け、パフォーマンスをより多くのブレークスルーを行います。

開発環境におけるPythonとJavaScriptの両方の選択が重要です。 1)Pythonの開発環境には、Pycharm、Jupyternotebook、Anacondaが含まれます。これらは、データサイエンスと迅速なプロトタイピングに適しています。 2)JavaScriptの開発環境には、フロントエンドおよびバックエンド開発に適したnode.js、vscode、およびwebpackが含まれます。プロジェクトのニーズに応じて適切なツールを選択すると、開発効率とプロジェクトの成功率が向上する可能性があります。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

メモ帳++7.3.1
使いやすく無料のコードエディター

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ドリームウィーバー CS6
ビジュアル Web 開発ツール

ホットトピック









