首頁 php框架 Laravel Laravel開發:如何使用Laravel Broadcasting實現事件廣播?

Laravel開發:如何使用Laravel Broadcasting實現事件廣播?

Jun 13, 2023 pm 07:56 PM
laravel broadcasting 事件廣播

在即時網路應用中,事件廣播是非常重要的功能之一。 Laravel框架提供了開箱即用的事件廣播功能,透過Laravel Broadcasting可以輕鬆實現事件的廣播和監聽。本文將介紹如何使用Laravel Broadcasting實現事件廣播。

一、理解事件廣播

在Web應用中,當某個事件發生時,例如用戶註冊成功、文章發佈等,我們希望其他用戶能夠及時收到相關資訊。此時,如果使用傳統的刷新頁面或Ajax輪詢的方式,會消耗大量的頻寬和伺服器資源,也無法滿足即時性的需求。事件廣播則可以解決這樣的問題。

事件廣播是將某個事件發射到特定的頻道或廣播群組中,然後監聽特定頻道或廣播群組的使用者就能夠即時收到相關訊息。透過事件廣播,可以大幅減少伺服器和用戶端之間的通訊次數,降低網路延遲和頻寬消耗,提升Web應用的效能和使用者體驗。

二、安裝Laravel Broadcasting

在使用Laravel Broadcasting之前,需要安裝Laravel Echo和相關的廣播驅動程式。 Laravel Echo是Laravel框架自帶的Socket.io客戶端庫,用於與廣播服務進行即時通訊。廣播驅動提供了與不同廣播服務互動的API,例如Redis和Pusher。在本文中,我們將使用Pusher作為廣播服務。

  1. 安裝Laravel Echo和Pusher SDK

透過npm安裝Laravel Echo和Pusher SDK:

npm install --save laravel-echo pusher-js
登入後複製
  1. 修改設定檔

開啟config/app.php文件,取消以下程式碼的註解:

AppProvidersBroadcastServiceProvider::class,
登入後複製

接著,在.env檔案中加入Pusher的相關設定:

BROADCAST_DRIVER=pusher

PUSHER_APP_ID=your-app-id
PUSHER_APP_KEY=your-app-key
PUSHER_APP_SECRET=your-app-secret
登入後複製

其中,your- app-id、your-app-key和your-app-secret需要根據實際情況進行修改。

三、創建事件和頻道

在Laravel中,事件是透過Event類別實現的。我們可以為每個需要廣播的事件建立一個對應的Event類別。在本文中,我們以使用者註冊成功為例來建立一個UserRegistered事件。首先,在終端機中執行以下指令建立UserRegistered事件類別:

php artisan make:event UserRegistered
登入後複製

接著,開啟app/Events/UserRegistered.php文件,將程式碼修改為:

namespace AppEvents;

use AppUser;
use IlluminateQueueSerializesModels;
use IlluminateFoundationEventsDispatchable;

class UserRegistered
{
    use Dispatchable, SerializesModels;

    public $user;

    /**
     * Create a new event instance.
     *
     * @param  AppUser  $user
     * @return void
     */
    public function __construct(User $user)
    {
        $this->user = $user;
    }

    /**
     * Get the channels the event should broadcast on.
     *
     * @return IlluminateBroadcastingChannel|array
     */
    public function broadcastOn()
    {
        return new Channel('user.'.$this->user->id);
    }
}
登入後複製

在上面的程式碼中,我們建立了一個UserRegistered事件類,並在建構方法中註入了User模型。然後,在broadcastOn()方法中,我們定義了事件需要廣播到的頻道,這裡以'user.{user_id}'的形式指定了一個私有頻道。

接著,我們需要建立一個UserChannel頻道,用於監聽'user.{user_id}'頻道的使用者。建立UserChannel頻道有兩種方式:手動註冊和自動發現。

手動註冊方式:

在app/Providers/BroadcastServiceProvider.php檔案中註冊UserChannel頻道:

use IlluminateSupportFacadesBroadcast;
use AppBroadcastingUserChannel;

Broadcast::channel('user.{userId}', UserChannel::class);
登入後複製

自動發現方式:

#在app/ Broadcasting目錄下建立一個UserChannel.php文件,將程式碼修改為:

namespace AppBroadcasting;

use AppUser;

class UserChannel
{
    /**
     * Create a new channel instance.
     *
     * @param  AppUser  $user
     * @return void
     */
    public function __construct(User $user)
    {
        $this->user = $user;
    }

    /**
     * Authenticate the user's access to the channel.
     *
     * @return array|bool
     */
    public function join(User $user, $userId)
    {
        return $user->id === (int) $userId;
    }
}
登入後複製

在上面的程式碼中,我們建立了一個UserChannel頻道類,並在建構方法中註入了User模型。然後,透過join()方法驗證使用者是否有權存取該頻道。

四、廣播事件

在建立好事件和頻道之後,我們可以使用broadcast()函數廣播事件到指定的頻道。在本文中,我們將在UserController類別中實現用戶註冊成功後廣播UserRegistered事件:

namespace AppHttpControllers;

use AppUser;
use AppEventsUserRegistered;
use IlluminateHttpRequest;

class UserController extends Controller
{
    /**
     * Register a new user.
     *
     * @param  IlluminateHttpRequest  $request
     * @return IlluminateHttpResponse
     */
    public function register(Request $request)
    {
        $user = new User([
            'name' => $request->input('name'),
            'email' => $request->input('email'),
            'password' => bcrypt($request->input('password')),
        ]);
        $user->save();

        event(new UserRegistered($user));

        return response()->json([
            'message' => 'User registered successfully!',
            'user' => $user,
        ]);
    }
}
登入後複製

在上面的程式碼中,我們首先建立了一個用戶,並進行了儲存操作。接著,使用event()函數廣播UserRegistered事件,以通知其他使用者有新使用者註冊成功了。

五、監聽事件

在創建好事件和頻道後,其他使用者就可以透過監聽對應的頻道來接收事件。接下來,我們將透過Laravel Echo監聽UserRegistered事件。

  1. 修改設定檔

首先,在resources/assets/js/bootstrap.js檔案中加入以下程式碼:

import Echo from 'laravel-echo';

window.Pusher = require('pusher-js');

window.Echo = new Echo({
    broadcaster: 'pusher',
    key: process.env.MIX_PUSHER_APP_KEY,
    cluster: process.env.MIX_PUSHER_APP_CLUSTER,
    encrypted: true
});
登入後複製

在上述程式碼中,我們使用Laravel Echo和Pusher SDK來連接Pusher廣播服務。可以在.env檔中設定PUSHER_APP_KEY和PUSHER_APP_CLUSTER。

  1. 建立監聽器

開啟resources/assets/js/app.js文件,在其中加入以下程式碼:

import Echo from 'laravel-echo';

window.Pusher = require('pusher-js');

window.Echo = new Echo({
    broadcaster: 'pusher',
    key: process.env.MIX_PUSHER_APP_KEY,
    cluster: process.env.MIX_PUSHER_APP_CLUSTER,
    encrypted: true
});

window.Echo.channel('user.' + userId)
    .listen('UserRegistered', (e) => {
        console.log(e);
    });
登入後複製

在上述程式碼中,我們透過window.Echo.channel()方法監聽'user.{user_id}'頻道,並指定了事件類型為'UserRegistered'。該程式碼將在使用者登入後執行,以確保每個使用者只是監聽自己的頻道。

六、測試

在應用程式中註冊一個新用戶,然後在控制台中查看是否收到了新的用戶註冊事件。

透過上述步驟,我們完成了使用Laravel Broadcasting實現事件廣播的過程。事件廣播是即時Web應用的重要功能之一,可大幅提升Web應用的效能與使用者體驗。

以上是Laravel開發:如何使用Laravel Broadcasting實現事件廣播?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Laravel和CodeIgniter的最新版本對比 Laravel和CodeIgniter的最新版本對比 Jun 05, 2024 pm 05:29 PM

Laravel9和CodeIgniter4的最新版本提供了更新的功能和改進。 Laravel9採用MVC架構,提供資料庫遷移、驗證及模板引擎等功能。 CodeIgniter4採用HMVC架構,提供路由、ORM和快取。在性能方面,Laravel9的基於服務提供者設計模式和CodeIgniter4的輕量級框架使其具有出色的性能。在實際應用中,Laravel9適用於需要靈活性和強大功能的複雜項目,而CodeIgniter4適用於快速開發和小型應用程式。

Laravel 和 CodeIgniter 中資料處理能力的比較如何? Laravel 和 CodeIgniter 中資料處理能力的比較如何? Jun 01, 2024 pm 01:34 PM

比較Laravel和CodeIgniter的資料處理能力:ORM:Laravel使用EloquentORM,提供類別物件關係映射,而CodeIgniter使用ActiveRecord,將資料庫模型表示為PHP類別的子類別。查詢建構器:Laravel具有靈活的鍊式查詢API,而CodeIgniter的查詢建構器更簡單,基於陣列。資料驗證:Laravel提供了一個Validator類,支援自訂驗證規則,而CodeIgniter的驗證功能內建較少,需要手動編碼自訂規則。實戰案例:用戶註冊範例展示了Lar

Laravel 和 CodeIgniter 對於初學者來說哪一個比較友善? Laravel 和 CodeIgniter 對於初學者來說哪一個比較友善? Jun 05, 2024 pm 07:50 PM

對於初學者來說,CodeIgniter的學習曲線更平緩,功能較少,但涵蓋了基本需求。 Laravel提供了更廣泛的功能集,但學習曲線稍陡。在性能方面,Laravel和CodeIgniter都表現出色。 Laravel有更廣泛的文件和活躍的社群支持,而CodeIgniter更簡單、輕量級,具有強大的安全功能。在建立部落格應用程式的實戰案例中,Laravel的EloquentORM簡化了資料操作,而CodeIgniter需要更多的手動配置。

Laravel和CodeIgniter:哪種框架更適合大型專案? Laravel和CodeIgniter:哪種框架更適合大型專案? Jun 04, 2024 am 09:09 AM

在選擇大型專案框架時,Laravel和CodeIgniter各有優勢。 Laravel針對企業級應用程式而設計,提供模組化設計、相依性注入和強大的功能集。 CodeIgniter是一款輕量級框架,更適合小型到中型項目,強調速度和易用性。對於具有複雜需求和大量用戶的大型項目,Laravel的強大功能和可擴展性更為合適。而對於簡單專案或資源有限的情況下,CodeIgniter的輕量級和快速開發能力則較為理想。

Laravel - Artisan 指令 Laravel - Artisan 指令 Aug 27, 2024 am 10:51 AM

Laravel - Artisan 指令 - Laravel 5.7 提供了處理和測試新指令的新方法。它包括測試 artisan 命令的新功能,下面提到了演示?

Laravel和CodeIgniter:哪種框架比較適合小型專案? Laravel和CodeIgniter:哪種框架比較適合小型專案? Jun 04, 2024 pm 05:29 PM

對於小型項目,Laravel適用於大型項目,需要強大的功能和安全性。 CodeIgniter適用於非常小的項目,需要輕量級和易用性。

Laravel 和 CodeIgniter 的模板引擎哪一個比較好? Laravel 和 CodeIgniter 的模板引擎哪一個比較好? Jun 03, 2024 am 11:30 AM

比較了Laravel的Blade和CodeIgniter的Twig模板引擎,根據專案需求和個人偏好進行選擇:Blade基於MVC語法,鼓勵良好程式碼組織和模板繼承。 Twig是第三方函式庫,提供靈活語法、強大過濾器、擴充支援和安全沙箱。

Laravel - 分頁自訂 Laravel - 分頁自訂 Aug 27, 2024 am 10:51 AM

Laravel - 分頁自訂 - Laravel 包含分頁功能,可協助使用者或開發人員包含分頁功能。 Laravel 分頁器與查詢產生器和 Eloquent ORM 整合。自動分頁方法

See all articles