실시간 웹 애플리케이션에서 이벤트 방송은 매우 중요한 기능 중 하나입니다. Laravel 프레임워크는 즉시 사용 가능한 이벤트 방송 기능을 제공하며, Laravel Broadcasting을 통해 이벤트 방송 및 모니터링을 쉽게 구현할 수 있습니다. 이 글에서는 Laravel Broadcasting을 사용하여 이벤트 브로드캐스팅을 구현하는 방법을 소개합니다.
1. 이벤트 방송 이해하기
웹 애플리케이션에서는 사용자 등록 성공, 기사 게시 등의 이벤트가 발생하면 다른 사용자가 제때에 관련 정보를 받을 수 있기를 바랍니다. 이때 기존의 페이지 새로 고침이나 Ajax 폴링 방식을 사용하면 대역폭과 서버 리소스가 많이 소모되어 실시간 수요를 충족할 수 없습니다. 이벤트 방송을 통해 이 문제를 해결할 수 있습니다.
이벤트 방송은 특정 채널이나 방송 그룹에 이벤트를 내보내고, 특정 채널이나 방송 그룹을 모니터링하는 사용자가 관련 정보를 즉시 받을 수 있도록 하는 것입니다. 이벤트 브로드캐스팅을 통해 서버와 클라이언트 간의 통신 횟수를 크게 줄일 수 있고, 네트워크 대기 시간과 대역폭 소비를 줄일 수 있으며, 웹 애플리케이션의 성능과 사용자 경험을 향상시킬 수 있습니다.
2. Laravel Broadcasting 설치
Laravel Broadcasting을 사용하기 전에 Laravel Echo 및 관련 브로드캐스트 드라이버를 설치해야 합니다. Laravel Echo는 Laravel 프레임워크와 함께 제공되는 Socket.io 클라이언트 라이브러리로, 방송 서비스와의 실시간 통신에 사용됩니다. 브로드캐스트 드라이버는 Redis 및 Pusher와 같은 다양한 브로드캐스트 서비스와 상호 작용하기 위한 API를 제공합니다. 이번 글에서는 Pusher를 방송 서비스로 활용해 보겠습니다.
npm을 통해 Laravel Echo 및 Pusher SDK 설치:
npm install --save laravel-echo pusher-js
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 이벤트를 수신하겠습니다.
먼저 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 파일에서 설정할 수 있습니다.
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!