cari
Rumahhujung hadapan webtutorial jsPemberitahuan Masa Nyata dengan Acara Dihantar Pelayan (SSE) dalam Laravel dan Vue.js

Real-Time Notifications with Server-Sent Events (SSE) in Laravel and Vue.js

Acara Dihantar Pelayan (SSE) ialah penyelesaian hebat untuk mendayakan pemberitahuan atau kemas kini masa nyata dalam aplikasi anda. Tidak seperti WebSockets, SSE membenarkan komunikasi sehala dari pelayan kepada pelanggan, menjadikannya ringan dan mudah untuk dilaksanakan. Dalam tutorial ini, kami akan membincangkan cara menyediakan SSE dalam bahagian belakang Laravel dan menggunakan acara dalam bahagian hadapan Vue.js.

Gambaran keseluruhan

Kami akan mencipta sistem pemberitahuan masa nyata yang ringkas menggunakan SSE. Pelayan (Laravel) akan menolak pemberitahuan kepada klien (Vue.js) apabila terdapat pemberitahuan baharu untuk pengguna yang disahkan. Berikut ialah pecahan perkara yang akan kami bincangkan:

  1. Backend (Laravel): Sediakan titik akhir SSE untuk menstrim pemberitahuan.
  2. Frontend (Vue.js): Sediakan EventSource untuk mendengar pemberitahuan masuk.

Langkah 1: Bahagian Belakang (Laravel)

1.1 Buat Laluan SSE dalam Laravel

Dalam route/api.php anda, buat titik akhir untuk strim SSE. Ini akan membolehkan bahagian hadapan Vue.js anda mewujudkan sambungan SSE dan mendengar pemberitahuan.
gunakan AppHttpControllersNotificationController;

Route::get('/notifications', [NotificationController::class, 'get']);

1.2 Kaedah Pengawal untuk Penstriman Pemberitahuan

Seterusnya, dalam NotificationController, laksanakan logik untuk mengambil pemberitahuan yang belum dibaca daripada pangkalan data dan menstrimnya kepada pelanggan melalui 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);
    }
}

Penjelasan:

Respons Penstriman: Kaedah respons()->stream() digunakan untuk menghantar aliran peristiwa yang tidak terhingga.
Pemberitahuan: Kami sedang menanyakan model Pemberitahuan untuk pemberitahuan yang belum dibaca (diklik = 0) untuk pengguna tertentu. Pemberitahuan dikodkan sebagai JSON dan dihantar kepada pelanggan.
Pengepala: Pengepala ditetapkan untuk SSE (Content-Type: text/event-stream).
Gelung Infinite: Gelung sementara (benar) memastikan sambungan terbuka dan menghantar pemberitahuan baharu secara berterusan setiap 5 saat (boleh laras dengan mengubah suai tidur(5)).

Langkah 2: Frontend (Vue.js)

Sekarang, mari sediakan bahagian hadapan Vue.js untuk mendengar pemberitahuan ini menggunakan API EventSource.

2.1. Sediakan Komponen Vue untuk Mendengar Acara SSE

Buat komponen Vue yang akan mendengar acara masuk daripada strim SSE.

<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>

Penjelasan:

  1. EventSource: Kami mencipta kejadian EventSource yang mendengar titik akhir /api/notifications. Ini mewujudkan sambungan berterusan ke pelayan. onmessage: Pendengar acara ini memproses mesej masuk. Data dihuraikan daripada JSON dan ditambahkan pada tatasusunan pemberitahuan. onerror: Jika ralat berlaku (cth., jika sambungan SSE hilang), kami log ralat dan tutup sambungan.
  2. beforeDestroy: Untuk mengelakkan kebocoran memori, sambungan SSE ditutup apabila komponen dimusnahkan.

Kesimpulan

Dalam tutorial ini, kami telah menyediakan pemberitahuan masa nyata menggunakan Acara Dihantar Pelayan (SSE) dalam bahagian belakang Laravel dan bahagian hadapan Vue.js. SSE menyediakan cara yang mudah dan cekap untuk menolak kemas kini masa nyata kepada pelanggan, menjadikannya pilihan yang sangat baik untuk ciri seperti pemberitahuan. Dengan persediaan yang minimum, anda boleh meningkatkan aplikasi anda dengan keupayaan masa nyata secara langsung.

Atas ialah kandungan terperinci Pemberitahuan Masa Nyata dengan Acara Dihantar Pelayan (SSE) dalam Laravel dan Vue.js. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Ganti aksara rentetan dalam javascriptGanti aksara rentetan dalam javascriptMar 11, 2025 am 12:07 AM

Penjelasan terperinci mengenai kaedah penggantian rentetan javascript dan Soalan Lazim Artikel ini akan meneroka dua cara untuk menggantikan watak rentetan dalam JavaScript: Kod JavaScript dalaman dan HTML dalaman untuk laman web. Ganti rentetan di dalam kod JavaScript Cara yang paling langsung ialah menggunakan kaedah pengganti (): str = str.replace ("cari", "ganti"); Kaedah ini hanya menggantikan perlawanan pertama. Untuk menggantikan semua perlawanan, gunakan ungkapan biasa dan tambahkan bendera global g: str = str.replace (/fi

Bina Aplikasi Web Ajax anda sendiriBina Aplikasi Web Ajax anda sendiriMar 09, 2025 am 12:11 AM

Jadi di sini anda, bersedia untuk mempelajari semua perkara ini yang dipanggil Ajax. Tetapi, apa sebenarnya? Istilah Ajax merujuk kepada kumpulan teknologi longgar yang digunakan untuk membuat kandungan web yang dinamik dan interaktif. Istilah Ajax, yang asalnya dicipta oleh Jesse J

10 JQuery Fun and Games Plugin10 JQuery Fun and Games PluginMar 08, 2025 am 12:42 AM

10 Plugin Permainan JQuery yang menyeronokkan untuk menjadikan laman web anda lebih menarik dan meningkatkan keletihan pengguna! Walaupun Flash masih merupakan perisian terbaik untuk membangunkan permainan web kasual, jQuery juga boleh menghasilkan kesan yang mengejutkan, dan walaupun tidak setanding dengan permainan flash aksi tulen, dalam beberapa kes, anda juga boleh bersenang -senang di penyemak imbas anda. permainan jquery tic toe "Hello World" pengaturcaraan permainan kini mempunyai versi jQuery. Kod sumber JQuery Game Composition Crazy Word Ini adalah permainan mengisi kosong, dan ia dapat menghasilkan beberapa hasil yang pelik kerana tidak mengetahui konteks perkataan. Kod sumber JQuery Mine Sweeping Game

JQuery Parallax Tutorial - Latar Belakang Header AnimasiJQuery Parallax Tutorial - Latar Belakang Header AnimasiMar 08, 2025 am 12:39 AM

Tutorial ini menunjukkan cara membuat kesan latar belakang paralaks yang menawan menggunakan jQuery. Kami akan membina sepanduk header dengan imej berlapis yang mewujudkan kedalaman visual yang menakjubkan. Plugin yang dikemas kini berfungsi dengan JQuery 1.6.4 dan kemudian. Muat turun

Bagaimana saya membuat dan menerbitkan perpustakaan JavaScript saya sendiri?Bagaimana saya membuat dan menerbitkan perpustakaan JavaScript saya sendiri?Mar 18, 2025 pm 03:12 PM

Artikel membincangkan membuat, menerbitkan, dan mengekalkan perpustakaan JavaScript, memberi tumpuan kepada perancangan, pembangunan, ujian, dokumentasi, dan strategi promosi.

Bagaimanakah saya mengoptimumkan kod JavaScript untuk prestasi dalam penyemak imbas?Bagaimanakah saya mengoptimumkan kod JavaScript untuk prestasi dalam penyemak imbas?Mar 18, 2025 pm 03:14 PM

Artikel ini membincangkan strategi untuk mengoptimumkan prestasi JavaScript dalam pelayar, memberi tumpuan kepada mengurangkan masa pelaksanaan dan meminimumkan kesan pada kelajuan beban halaman.

Bermula dengan Matter.js: PengenalanBermula dengan Matter.js: PengenalanMar 08, 2025 am 12:53 AM

Matter.js adalah enjin fizik badan tegar 2D yang ditulis dalam JavaScript. Perpustakaan ini dapat membantu anda dengan mudah mensimulasikan fizik 2D dalam penyemak imbas anda. Ia menyediakan banyak ciri, seperti keupayaan untuk mencipta badan yang tegar dan menetapkan sifat fizikal seperti jisim, kawasan, atau ketumpatan. Anda juga boleh mensimulasikan pelbagai jenis perlanggaran dan daya, seperti geseran graviti. Matter.js menyokong semua pelayar arus perdana. Di samping itu, ia sesuai untuk peranti mudah alih kerana ia mengesan sentuhan dan responsif. Semua ciri-ciri ini menjadikannya bernilai masa untuk belajar menggunakan enjin, kerana ini memudahkan untuk membuat permainan atau simulasi 2D berasaskan fizik. Dalam tutorial ini, saya akan merangkumi asas -asas perpustakaan ini, termasuk pemasangan dan penggunaannya, dan menyediakan

Kandungan Div Refresh Auto Menggunakan JQuery dan AjaxKandungan Div Refresh Auto Menggunakan JQuery dan AjaxMar 08, 2025 am 12:58 AM

Artikel ini menunjukkan bagaimana untuk menyegarkan semula kandungan div secara automatik setiap 5 saat menggunakan jQuery dan Ajax. Contohnya mengambil dan memaparkan catatan blog terkini dari suapan RSS, bersama -sama dengan timestamp refresh terakhir. Imej pemuatan adalah opsyena

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa