


Server-Sent Events (SSE) ist eine großartige Lösung, um Echtzeitbenachrichtigungen oder -aktualisierungen in Ihrer Anwendung zu ermöglichen. Im Gegensatz zu WebSockets ermöglicht SSE eine unidirektionale Kommunikation vom Server zum Client, wodurch es leichtgewichtig und einfach zu implementieren ist. In diesem Tutorial erfahren Sie, wie Sie SSE in einem Laravel-Backend einrichten und die Ereignisse in einem Vue.js-Frontend nutzen.
Überblick
Wir werden mit SSE ein einfaches Echtzeit-Benachrichtigungssystem erstellen. Der Server (Laravel) sendet Benachrichtigungen an den Client (Vue.js), wenn neue Benachrichtigungen für den authentifizierten Benutzer vorliegen. Hier ist eine Aufschlüsselung dessen, was wir behandeln werden:
- Backend (Laravel): Richten Sie einen SSE-Endpunkt ein, um Benachrichtigungen zu streamen.
- Frontend (Vue.js): Richten Sie eine EventSource ein, um auf eingehende Benachrichtigungen zu warten.
Schritt 1: Backend (Laravel)
1.1 Erstellen Sie eine SSE-Route in Laravel
Erstellen Sie in Ihrer Routes/api.php einen Endpunkt für den SSE-Stream. Dadurch kann Ihr Vue.js-Frontend eine SSE-Verbindung herstellen und auf Benachrichtigungen warten.
verwenden Sie AppHttpControllersNotificationController;
Route::get('/notifications', [NotificationController::class, 'get']);
1.2 Controller-Methode für Streaming-Benachrichtigungen
Als nächstes implementieren Sie im NotificationController die Logik, um ungelesene Benachrichtigungen aus der Datenbank abzurufen und sie über SSE an den Client zu streamen.
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); } }
Erklärung:
Streaming-Antwort: Die Methode „response()->stream()“ wird verwendet, um einen unendlichen Strom von Ereignissen zu senden.
Benachrichtigungen: Wir fragen das Benachrichtigungsmodell nach ungelesenen Benachrichtigungen (angeklickt = 0) für einen bestimmten Benutzer ab. Die Benachrichtigungen werden als JSON codiert und an den Client gesendet.
Header: Die Header sind für SSE festgelegt (Content-Type: Text/Event-Stream).
Endlosschleife: Die While-Schleife (wahr) hält die Verbindung offen und sendet kontinuierlich alle 5 Sekunden neue Benachrichtigungen (einstellbar durch Ändern von Sleep(5)).
Schritt 2: Frontend (Vue.js)
Jetzt richten wir das Vue.js-Frontend so ein, dass es mithilfe der EventSource-API auf diese Benachrichtigungen wartet.
2.1. Richten Sie die Vue-Komponente so ein, dass sie auf SSE-Ereignisse wartet
Erstellen Sie eine Vue-Komponente, die auf eingehende Ereignisse aus dem SSE-Stream wartet.
<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>
Erklärung:
- EventSource: Wir erstellen eine EventSource-Instanz, die auf den Endpunkt /api/notifications lauscht. Dadurch wird eine dauerhafte Verbindung zum Server hergestellt. onmessage: Dieser Event-Listener verarbeitet eingehende Nachrichten. Die Daten werden von JSON geparst und dem Benachrichtigungsarray hinzugefügt. onerror: Wenn ein Fehler auftritt (z. B. wenn die SSE-Verbindung verloren geht), protokollieren wir den Fehler und schließen die Verbindung.
- beforeDestroy: Um Speicherlecks zu verhindern, wird die SSE-Verbindung geschlossen, wenn die Komponente zerstört wird.
Abschluss
In diesem Tutorial haben wir Echtzeitbenachrichtigungen mithilfe von Server-Sent Events (SSE) in einem Laravel-Backend und einem Vue.js-Frontend eingerichtet. SSE bietet eine einfache und effiziente Möglichkeit, Aktualisierungen in Echtzeit an den Client zu übertragen, was es zu einer hervorragenden Wahl für Funktionen wie Benachrichtigungen macht. Mit minimalem Setup können Sie Ihre Anwendung mit Live-Echtzeitfunktionen erweitern.
Das obige ist der detaillierte Inhalt vonEchtzeitbenachrichtigungen mit Server-Sent Events (SSE) in Laravel und Vue.js. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Detaillierte Erläuterung der Methode für JavaScript -Zeichenfolge und FAQ In diesem Artikel werden zwei Möglichkeiten untersucht, wie String -Zeichen in JavaScript ersetzt werden: Interner JavaScript -Code und interne HTML für Webseiten. Ersetzen Sie die Zeichenfolge im JavaScript -Code Die direkteste Möglichkeit ist die Verwendung der Ersatz () -Methode: str = str.replace ("find", "ersetzen"); Diese Methode ersetzt nur die erste Übereinstimmung. Um alle Übereinstimmungen zu ersetzen, verwenden Sie einen regulären Ausdruck und fügen Sie das globale Flag G hinzu:: STR = Str.Replace (/fi

Dieses Tutorial zeigt Ihnen, wie Sie eine benutzerdefinierte Google -Such -API in Ihr Blog oder Ihre Website integrieren und ein raffinierteres Sucherlebnis bieten als Standard -WordPress -Themen -Suchfunktionen. Es ist überraschend einfach! Sie können die Suche auf y beschränken

Diese Artikelserie wurde Mitte 2017 mit aktuellen Informationen und neuen Beispielen umgeschrieben. In diesem JSON -Beispiel werden wir uns ansehen, wie wir einfache Werte in einer Datei mit JSON -Format speichern können. Mit der Notation des Schlüsselwertpaares können wir jede Art speichern

Hier sind Sie also bereit, alles über dieses Ding namens Ajax zu lernen. Aber was genau ist das? Der Begriff AJAX bezieht sich auf eine lose Gruppierung von Technologien, mit denen dynamische, interaktive Webinhalte erstellt werden. Der Begriff Ajax, ursprünglich von Jesse J geprägt

Nutzen Sie JQuery für mühelose Webseiten -Layouts: 8 Essential Plugins JQuery vereinfacht das Webseitenlayout erheblich. In diesem Artikel werden acht leistungsstarke JQuery -Plugins hervorgehoben, die den Prozess optimieren, insbesondere nützlich für die manuelle Website -Erstellung

Kernpunkte Dies in JavaScript bezieht sich normalerweise auf ein Objekt, das die Methode "besitzt", aber es hängt davon ab, wie die Funktion aufgerufen wird. Wenn es kein aktuelles Objekt gibt, bezieht sich dies auf das globale Objekt. In einem Webbrowser wird es durch Fenster dargestellt. Wenn Sie eine Funktion aufrufen, wird das globale Objekt beibehalten. Sie können den Kontext mithilfe von Methoden wie CALL (), Apply () und Bind () ändern. Diese Methoden rufen die Funktion mit dem angegebenen Wert und den Parametern auf. JavaScript ist eine hervorragende Programmiersprache. Vor ein paar Jahren war dieser Satz

JQuery ist ein großartiges JavaScript -Framework. Wie in jeder Bibliothek ist es jedoch manchmal notwendig, unter die Motorhaube zu gehen, um herauszufinden, was los ist. Vielleicht liegt es daran, dass Sie einen Fehler verfolgen oder nur neugierig darauf sind, wie JQuery eine bestimmte Benutzeroberfläche erreicht

Dieser Beitrag erstellt hilfreiche Cheat -Blätter, Referenzführer, schnelle Rezepte und Code -Snippets für die Entwicklung von Android-, Blackberry und iPhone -App. Kein Entwickler sollte ohne sie sein! Touch Gesten -Referenzhandbuch (PDF) Eine wertvolle Ressource für Desig


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

MantisBT
Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)
