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

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

Laravel은 웹 응용 프로그램을 쉽게 구축하기위한 PHP 프레임 워크입니다. 설치 : Composer를 사용하여 전 세계적으로 Laravel CLI를 설치하고 프로젝트 디렉토리에서 응용 프로그램을 작성하는 등 다양한 기능을 제공합니다. 라우팅 : Routes/Web.php에서 URL과 핸들러 간의 관계를 정의하십시오. 보기 : 리소스/뷰에서보기를 작성하여 응용 프로그램의 인터페이스를 렌더링합니다. 데이터베이스 통합 : MySQL과 같은 데이터베이스와 상자 외 통합을 제공하고 마이그레이션을 사용하여 테이블을 작성하고 수정합니다. 모델 및 컨트롤러 : 모델은 데이터베이스 엔티티를 나타내고 컨트롤러는 HTTP 요청을 처리합니다.

CRAFTCMS를 사용하여 웹 사이트를 개발할 때 특히 CSS 및 JavaScript 파일을 자주 업데이트 할 때 자주 리소스 파일 캐싱 문제가 발생하면 이전 버전의 파일이 여전히 브라우저에서 캐싱 될 수 있으므로 사용자는 최신 변경 사항을 볼 수 없습니다. 이 문제는 사용자 경험에 영향을 줄뿐만 아니라 개발 및 디버깅의 어려움을 증가시킵니다. 최근에 나는 프로젝트에서 비슷한 문제를 겪었고, 약간의 탐색 후 플러그인 Wiejeben/Craft-Laravel-Mix를 발견하여 캐싱 문제를 완벽하게 해결했습니다.

Laravel 프레임 워크를 배우고 싶지만 자원이나 경제적 압력이 없습니까? 이 기사는 Laravel의 무료 학습을 제공하며 온라인 플랫폼, 문서 및 커뮤니티 포럼과 같은 리소스를 사용하여 PHP 개발 여정을 시작하는 것에서 마스터까지의 탄탄한 토대를 마련하는 방법을 가르쳐줍니다.

Laravel provides a comprehensive Auth framework for implementing user login functions, including: Defining user models (Eloquent model), creating login forms (Blade template engine), writing login controllers (inheriting Auth\LoginController), verifying login requests (Auth::attempt) Redirecting after login is successful (redirect) considering security factors: hash passwords, anti-CSRF protection, rate limiting and security 헤더. 또한 Auth Framework는 비밀번호 재설정, 이메일 등록 및 확인과 같은 기능도 제공합니다. 자세한 내용은 Laravel 문서를 참조하십시오 : https://laravel.com/doc

초보자를위한 Laravel Framework 버전 선택 안내서 에서이 기사는 초보자가 많은 버전 중에서 정보에 입각 한 선택을하는 데 도움이되도록 설계된 Laravel의 버전 차이점으로 뛰어 들었습니다. 우리는 각 릴리스의 주요 기능에 중점을두고 장단점을 비교하며 초보자가 기술 수준 및 프로젝트 요구 사항에 따라 가장 적합한 Laravel 버전을 선택할 수 있도록 유용한 조언을 제공 할 것입니다. 초보자에게는 적절한 버전의 Laravel을 선택하는 것이 학습 곡선과 전반적인 개발 경험에 크게 영향을 줄 수 있기 때문에 중요합니다.

기사 요약 :이 기사는 Laravel 프레임 워크를 쉽게 설치하는 방법에 대한 독자들을 안내하기위한 자세한 단계별 지침을 제공합니다. Laravel은 웹 애플리케이션의 개발 프로세스를 가속화하는 강력한 PHP 프레임 워크입니다. 이 자습서는 시스템 요구 사항에서 데이터베이스 구성 및 라우팅 설정에 이르기까지 설치 프로세스를 다룹니다. 이러한 단계를 수행함으로써 독자들은 라벨 프로젝트를위한 탄탄한 토대를 빠르고 효율적으로 놓을 수 있습니다.

Laravel 프레임 워크에는 개발자의 다양한 요구를 충족시키기 위해 버전 번호를 쉽게 볼 수있는 내장 방법이 있습니다. 이 기사는 Composer Command Line 도구 사용, .env 파일에 액세스하거나 PHP 코드를 통해 버전 정보를 얻는 것을 포함하여 이러한 방법을 탐색합니다. 이러한 방법은 Laravel 애플리케이션의 버전 관리를 유지 관리하고 관리하는 데 필수적입니다.

Laravel과 ThinkPHP는 모두 인기있는 PHP 프레임 워크이며 개발에 고유 한 장점과 단점이 있습니다. 이 기사는 두 가지 깊이를 비교하여 건축, 기능 및 성능 차이를 강조하여 개발자가 특정 프로젝트 요구에 따라 정보에 입각 한 선택을 할 수 있도록 도와줍니다.
