>  기사  >  PHP 프레임워크  >  Laravel 개발: Laravel Broadcasting을 사용하여 이벤트 브로드캐스팅을 구현하는 방법은 무엇입니까?

Laravel 개발: Laravel Broadcasting을 사용하여 이벤트 브로드캐스팅을 구현하는 방법은 무엇입니까?

PHPz
PHPz원래의
2023-06-13 19:56:41967검색

실시간 웹 애플리케이션에서 이벤트 방송은 매우 중요한 기능 중 하나입니다. Laravel 프레임워크는 즉시 사용 가능한 이벤트 방송 기능을 제공하며, Laravel Broadcasting을 통해 이벤트 방송 및 모니터링을 쉽게 구현할 수 있습니다. 이 글에서는 Laravel Broadcasting을 사용하여 이벤트 브로드캐스팅을 구현하는 방법을 소개합니다.

1. 이벤트 방송 이해하기

웹 애플리케이션에서는 사용자 등록 성공, 기사 게시 등의 이벤트가 발생하면 다른 사용자가 제때에 관련 정보를 받을 수 있기를 바랍니다. 이때 기존의 페이지 새로 고침이나 Ajax 폴링 방식을 사용하면 대역폭과 서버 리소스가 많이 소모되어 실시간 수요를 충족할 수 없습니다. 이벤트 방송을 통해 이 문제를 해결할 수 있습니다.

이벤트 방송은 특정 채널이나 방송 그룹에 이벤트를 내보내고, 특정 채널이나 방송 그룹을 모니터링하는 사용자가 관련 정보를 즉시 받을 수 있도록 하는 것입니다. 이벤트 브로드캐스팅을 통해 서버와 클라이언트 간의 통신 횟수를 크게 줄일 수 있고, 네트워크 대기 시간과 대역폭 소비를 줄일 수 있으며, 웹 애플리케이션의 성능과 사용자 경험을 향상시킬 수 있습니다.

2. Laravel Broadcasting 설치

Laravel Broadcasting을 사용하기 전에 Laravel Echo 및 관련 브로드캐스트 드라이버를 설치해야 합니다. Laravel Echo는 Laravel 프레임워크와 함께 제공되는 Socket.io 클라이언트 라이브러리로, 방송 서비스와의 실시간 통신에 사용됩니다. 브로드캐스트 드라이버는 Redis 및 Pusher와 같은 다양한 브로드캐스트 서비스와 상호 작용하기 위한 API를 제공합니다. 이번 글에서는 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은 실제 상황에 따라 수정해야 합니다.

3. 이벤트 및 채널 생성

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 이벤트를 생성했습니다. 클래스, 그리고 생성 메소드에 사용자 모델을 주입했습니다. 그런 다음 BroadcastOn() 메서드에서 이벤트를 브로드캐스팅해야 하는 채널을 정의합니다. 여기서 비공개 채널은 'user.{user_id}' 형식으로 지정됩니다.

다음으로 'user.{user_id}' 채널의 사용자를 모니터링하기 위해 UserChannel 채널을 생성해야 합니다. 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() 메소드를 통해 사용자가 채널에 액세스할 수 있는지 확인하십시오.

4. 이벤트 방송

이벤트와 채널을 생성한 후 방송() 함수를 사용하여 지정된 채널에 이벤트를 방송할 수 있습니다. 이 기사에서는 성공적인 사용자 등록 후 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 이벤트를 브로드캐스트하여 새 사용자가 성공적으로 등록되었음을 다른 사용자에게 알립니다.

5. 이벤트 모니터링

이벤트 및 채널을 생성한 후 다른 사용자가 해당 채널을 모니터링하여 이벤트를 받을 수 있습니다. 다음으로 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 방송 서비스에 연결합니다. . PUSHER_APP_KEY 및 PUSHER_APP_CLUSTER는 .env 파일에서 설정할 수 있습니다.

  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를 통해 'user.{를 수신합니다. 채널() 메소드 user_id}' 채널이며, 이벤트 유형은 'UserRegistered'로 지정됩니다. 이 코드는 각 사용자가 자신의 채널만 듣고 있는지 확인하기 위해 사용자가 로그인한 후에 실행됩니다.

6. Test

애플리케이션에서 신규 사용자를 등록한 후 콘솔에서 신규 사용자 등록 이벤트가 수신되는지 확인합니다.

위의 과정을 거쳐 Laravel Broadcasting을 이용한 이벤트 방송 구현 과정이 완료되었습니다. 이벤트 브로드캐스팅은 실시간 웹 애플리케이션의 중요한 기능 중 하나이며, 이는 웹 애플리케이션의 성능과 사용자 경험을 크게 향상시킬 수 있습니다.

위 내용은 Laravel 개발: Laravel Broadcasting을 사용하여 이벤트 브로드캐스팅을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.