Laravel의 모델 이벤트에 대한 가이드
이들은 행동하고자하는 앱에서 발생하는 일입니다. 예를 들어, 사용자는 웹 사이트에 가입하고 사용자 로그인하는 등입니다.
디렉토리에 저장됩니다.
파견되면 이벤트가 듣는 청취자를 트리거합니다.
다음은 사용자가 등록 할 때 이벤트를 예약하는 방법의 간단한 예입니다.
app/Events
예를 들어,
declare(strict_types=1); namespace App\Events; use App\Models\User; use Illuminate\Broadcasting\InteractsWithSockets; use Illuminate\Foundation\Events\Dispatchable; use Illuminate\Queue\SerializesModels; final class UserRegistered { use Dispatchable; use InteractsWithSockets; use SerializesModels; public function __construct(public User $user) { // } }
검색된 - 데이터베이스에서 검색합니다.
만들기 - 모델 생성.생성 된
declare(strict_types=1); namespace App\Events; use App\Models\User; use Illuminate\Broadcasting\InteractsWithSockets; use Illuminate\Foundation\Events\Dispatchable; use Illuminate\Queue\SerializesModels; final class UserRegistered { use Dispatchable; use InteractsWithSockets; use SerializesModels; public function __construct(public User $user) { // } }
삭제 - 모델이 삭제되었습니다.
쓰레기 - 모델이 부드럽게 삭제되었습니다.-
강제로 - 모델은 삭제되도록 강요당했습니다 -
복원 - 모델은 소프트 삭제에서 복구되었습니다.
복제 - 모델을 복제합니다. -
Laravel 애플리케이션에서 이러한 모델 이벤트를 사용하는 방법을 살펴 보겠습니다. - 사용 모델 이벤트 듣기 모델 이벤트를 듣는 한 가지 방법은 모델에서 속성을 정의하는 것입니다.
- 이 속성을 사용하면 이벤트가 발생할 때 예약 해야하는 이벤트 클래스에 웅변 모델 이벤트를 매핑 할 수 있습니다. 즉, 다른 이벤트를 처리하는 것처럼 청취자를 정의 할 수 있습니다.
-
우리가 두 가지 모델의 블로그 애플리케이션을 구축한다고 가정 해 봅시다 : 와 . 우리는 두 모델 모두 소프트 삭제를 지원한다고 말할 것입니다. 새로운 를 저장하면 내용의 길이를 기반으로 기사의 읽기 시간을 계산하려고합니다. 저자를 부드럽게 삭제하면 저자가 모든 기사를 부드럽게 삭제하기를 원합니다. -
##모델을 세트
우리는 다음과 같이 모델을 가질 수 있습니다 :
-
위의 모델에는 다음과 같습니다 - 는 모델 이벤트를 이벤트 클래스에 매핑하는 속성을 추가했습니다. 즉, 모델이 삭제되면 새 이벤트가 예정되어 있음을 의미합니다. 나중에이 이벤트 클래스를 만들 것입니다.
dispatchesEvents
관계를 정의합니다.deleted
피처를 사용하여 모델에서 소프트 삭제가 활성화됩니다. AppEventsAuthorDeleted
AppEventsAuthorDeleted
모델을 만들어 봅시다
-
위의
posts
모델에는 다음과 같습니다 - 는 모델 이벤트를 이벤트 클래스에 매핑하는 속성을 추가했습니다. 즉, 모델이 생성되거나 업데이트되면 새 이벤트가 예정되어 있음을 의미합니다. 나중에이 이벤트 클래스를 만들 것입니다.
IlluminateDatabaseEloquentSoftDeletes
관계를 정의합니다.
피처를 사용하여 모델에서 소프트 삭제가 활성화됩니다. 우리 모델이 준비되었으므로 및 AppModelsPost
이벤트 클래스를 만들어 봅시다.##이벤트 클래스를 생성합니다 우리는 새 기사를 저장할 때 예정 될 이벤트 클래스를 만들 것입니다.declare(strict_types=1); namespace App\Events; use App\Models\User; use Illuminate\Broadcasting\InteractsWithSockets; use Illuminate\Foundation\Events\Dispatchable; use Illuminate\Queue\SerializesModels; final class UserRegistered { use Dispatchable; use InteractsWithSockets; use SerializesModels; public function __construct(public User $user) { // } }
로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사위 코드에서는 이벤트 클래스를 볼 수 있으며,이 클래스는 생성자에서 모델 인스턴스를 허용합니다. 이 이벤트 클래스는 저장되는 기사 인스턴스를 저장하기위한 간단한 컨테이너입니다. <code>AppModelsPost
마찬가지로, 저자를 삭제할 때 예정 될 -
위의
- 클래스에서는 생성자가 모델 인스턴스를 수락한다는 것을 알 수 있습니다.
dispatchesEvents
이제 우리는 청취자를 계속 만들 수 있습니다. saving
#생성자를 강조하십시오 먼저 기사의 읽기 시간 추정을 계산하는 데 사용할 수있는 리스너를 만들어 봅시다. AppEventsPostSaving
우리는 새로운AppEventsPostSaving
리스너 클래스를 만들 것입니다 : - 메소드 만 있습니다. 이것은
author
이벤트를 예약 할 때 자동으로 호출되는 메소드입니다. 저장중인 기사가 포함 된 이벤트 클래스의 인스턴스를 수락합니다. -
IlluminateDatabaseEloquentSoftDeletes
방법에서는 간단한 공식을 사용하여 기사의 읽기 시간을 계산합니다. 이 예에서는 평균 판독 속도가 분당 265 단어라고 가정합니다. 우리는 읽기 시간을 몇 초 만에 계산 한 다음 기사 모델에서 속성을 설정합니다.
위의 코드에서 볼 수 있듯이 하나의 이 리스너가 모델 이벤트가 트리거 될 때 호출되므로, 이는 기사를 작성하거나 업데이트하기 전에 기사가 데이터베이스에 지속될 때마다 속성이 계산된다는 것을 의미합니다.
리스너 클래스를 만들 수 있습니다saving
우리는 또한 저자를 부드럽게 삭제할 때 모든 관련 기사를 부드럽게 삭제하는 리스너를 만들 수 있습니다. read_time_in_seconds
우리는 새로운위의 리스너에서
따라서메소드는 이벤트 클래스의 인스턴스를 허용합니다. 이 이벤트 클래스에는 저자가 삭제되는 것이 포함되어 있습니다. 그런 다음 저자의 기사를 삭제하기 위해 따라서 모델이 부드럽게 삭제 될 때마다 모든 저자의 기사도 부드럽게 삭제됩니다.
AppListenersSoftDeleteAuthorRelationships
그건 그렇고,이를 달성하기 위해보다 강력하고 재사용 가능한 솔루션을 사용하고 싶을 수도 있습니다. 그러나이 기사의 목적 상, 우리는 그것을 간단하게 유지합니다.클로저를 사용하여 모델 이벤트를 듣습니다 declare(strict_types=1); namespace App\Events; use App\Models\User; use Illuminate\Broadcasting\InteractsWithSockets; use Illuminate\Foundation\Events\Dispatchable; use Illuminate\Queue\SerializesModels; final class UserRegistered { use Dispatchable; use InteractsWithSockets; use SerializesModels; public function __construct(public User $user) { // } }
로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사당신이 사용할 수있는 또 다른 방법은 리스너를 모델 자체의 클로저로 정의하는 것입니다. 모델 클래스를 열 때 관찰자를 등록하는지 즉시 확인할 수 있기 때문에 청취자 로직을 정의하는 방법이 정말 마음에 듭니다. 따라서 논리는 여전히 별도의 파일에 "숨겨져"있지만, 우리는 최소한 하나의 모델 이벤트에 대해 청취자를 등록했음을 알 수 있습니다. 그러나 이러한 폐쇄의 코드가 더 복잡해지면 별도의 청취자 클래스로 논리를 추출하는 것이 좋습니다. 편리한 속임수는 AppModelsAuthor
함수를 사용하여 클로저를 대기시킬 수 있다는 것입니다. 이는 리스너의 코드가 동일한 요청 수명주기가 아닌 백그라운드에서 실행되도록 대기열로 밀려 나게한다는 것을 의미합니다. 다음과 같이 리스너를 queuable로 업데이트 할 수 있습니다.위의 예에서 보았 듯이, 우리는 함수로 클로저를 랩핑합니다.
옵저버를 사용하여 모델 이벤트를 듣습니다 모델 이벤트를들을 수있는 또 다른 방법은 모델 관찰자를 사용하는 것입니다. 모델 관찰자를 사용하면 한 클래스에서 모델의 모든 리스너를 정의 할 수 있습니다. 일반적으로, 그들은
디렉토리에 존재하는 클래스이며, 듣고 싶은 모델 이벤트에 해당하는 방법이 있습니다. 예를 들어, 모델 이벤트를 듣고 싶다면 관찰자 클래스에서메소드를 정의합니다. 모델 이벤트를 듣고 싶다면 관찰자 클래스에서
메소드를 정의합니다.모델 이벤트를 듣는 모델을위한 모델 관찰자를 만드는 방법을 살펴 보겠습니다 : app/Observers
위의 코드에서 볼 수 있듯이 deleted
메소드가있는 관찰자를 만듭니다. 이 메소드는deleted
모델의 인스턴스가 삭제되는 인스턴스를 허용합니다. 그런 다음 저자의 기사를 삭제하기 위해나는 청취자 논리를 정의하는 방법을 정말로 좋아합니다. 모델 클래스를 열 때 관찰자를 등록하는지 즉시 확인할 수 있기 때문입니다. 따라서 논리는 여전히 별도의 파일에 "숨겨져"있지만, 우리는 최소한 하나의 모델 이벤트에 대해 청취자를 등록했음을 알 수 있습니다. AppModelsAuthor
모델 이벤트를 테스트하십시오 deleted
어떤 모델 이벤트 메소드를 사용하든 논리가 예상대로 작동하는지 확인하기 위해 일부 테스트를 작성할 수 있습니다. 위의 예제에서 만든 모델 이벤트를 테스트하는 방법을 살펴 보겠습니다. 저자가 부드럽게 삭제 될 때 저자의 기사가 부드럽게 삭제되도록 테스트를 작성합니다. 테스트는 다음과 같이 보일 수 있습니다declare(strict_types=1); namespace App\Events; use App\Models\User; use Illuminate\Broadcasting\InteractsWithSockets; use Illuminate\Foundation\Events\Dispatchable; use Illuminate\Queue\SerializesModels; final class UserRegistered { use Dispatchable; use InteractsWithSockets; use SerializesModels; public function __construct(public User $user) { // } }
로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사위의 테스트에서 우리는 해당 저자를위한 새로운 저자와 기사를 만들고 있습니다. 그런 다음 저자를 부드럽게 삭제하고 저자와 기사가 모두 부드럽게 삭제되었다고 주장했습니다. deleted
이것은 우리의 논리가 예상대로 작동하는지 확인하는 데 사용할 수있는 매우 간단하지만 효과적인 테스트입니다. 이 테스트의 장점은이 기사에서 논의하는 각 방법과 함께 작동해야한다는 것입니다. 따라서이 기사에서 논의한 방법 중 하나를 전환하면 테스트가 여전히 전달되어야합니다. AppModelsAuthor
마찬가지로, 기사의 읽기 시간이 작성하거나 업데이트 될 때 계산되도록 몇 가지 테스트를 작성할 수 있습니다. 테스트는 다음과 같이 보일 수 있습니다 우리는 두 가지 테스트가 있습니다 : 첫 번째 테스트는 기사의 읽기 시간을 만들 때 계산되도록합니다. declare(strict_types=1); namespace App\Events; use App\Models\User; use Illuminate\Broadcasting\InteractsWithSockets; use Illuminate\Foundation\Events\Dispatchable; use Illuminate\Queue\SerializesModels; final class UserRegistered { use Dispatchable; use InteractsWithSockets; use SerializesModels; public function __construct(public User $user) { // } }
로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사로그인 후 복사두 번째 테스트는 기사의 읽기 시간이 기사를 업데이트 할 때 계산되도록합니다. 모델 이벤트를 사용할 때의 예방 조치 모델 이벤트는 매우 편리하지만 사용할 때 알아야 할 몇 가지 문제가 있습니다. 모델 이벤트는 웅변 모델에서만 예약됩니다. 즉, 데이터베이스에서 모델의 기본 데이터와 상호 작용하기 위해 - Facade를 사용하는 경우 이벤트가 예약되지 않습니다.
예를 들어, 간단한 예를 살펴 보겠습니다. - 는 모델 이벤트를 이벤트 클래스에 매핑하는 속성을 추가했습니다. 즉, 모델이 삭제되면 새 이벤트가 예정되어 있음을 의미합니다. 나중에이 이벤트 클래스를 만들 것입니다.
위의 코드를 실행하면 예상대로 데이터베이스에서 저자를 삭제합니다. 그러나 모델 이벤트는 예약되지 않습니다. 따라서 저자를 삭제할 때 이러한 모델 이벤트에 대한 청취자를 정의하면 실행되지 않습니다. <hr>
마찬가지로, Eloquent를 사용하여 Batch 업데이트 또는 모델을 삭제하는 경우 , <p>, </p> 및 <p> 모델 이벤트는 영향을받는 모델에 대해 예약되지 않습니다. 이벤트는 모델 자체에서 예약되기 때문입니다. 그러나 배치 업데이트 및 삭제가 업데이트되면 모델은 실제로 데이터베이스에서 검색되지 않으므로 이벤트가 예약되지 않습니다. <code>IlluminateSupportFacadesDB
예를 들어 다음 코드를 사용하여 저자를 삭제한다고 가정 해 봅시다.
메소드는 쿼리 빌더에서 직접 호출되므로 및 모델 이벤트는 해당 저자에 대해 예약되지 않습니다. IlluminateSupportFacadesDB
위 내용은 Laravel의 모델 이벤트에 대한 가이드의 상세 내용입니다. 자세한 내용은 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)

세션 납치는 다음 단계를 통해 달성 할 수 있습니다. 1. 세션 ID를 얻으십시오. 2. 세션 ID 사용, 3. 세션을 활성 상태로 유지하십시오. PHP에서 세션 납치를 방지하는 방법에는 다음이 포함됩니다. 1. 세션 _regenerate_id () 함수를 사용하여 세션 ID를 재생산합니다. 2. 데이터베이스를 통해 세션 데이터를 저장하십시오.

PHP에는 4 가지 주요 오류 유형이 있습니다. 1. NOTICE : 가장 작은 것은 정의되지 않은 변수에 액세스하는 것과 같이 프로그램을 방해하지 않습니다. 2. 경고 : 심각한 통지는 파일을 포함하지 않는 것과 같은 프로그램을 종료하지 않습니다. 3. FatalError : 가장 심각한 것은 기능을 부르는 것과 같은 프로그램을 종료합니다. 4. parseerror : 구문 오류는 엔드 태그를 추가하는 것을 잊어 버리는 것과 같이 프로그램이 실행되는 것을 방지합니다.

PHP와 Python은 각각 고유 한 장점이 있으며 프로젝트 요구 사항에 따라 선택합니다. 1.PHP는 웹 개발, 특히 웹 사이트의 빠른 개발 및 유지 보수에 적합합니다. 2. Python은 간결한 구문을 가진 데이터 과학, 기계 학습 및 인공 지능에 적합하며 초보자에게 적합합니다.

HTTP 요청 방법에는 각각 리소스를 확보, 제출, 업데이트 및 삭제하는 데 사용되는 Get, Post, Put and Delete가 포함됩니다. 1. GET 방법은 리소스를 얻는 데 사용되며 읽기 작업에 적합합니다. 2. 게시물은 데이터를 제출하는 데 사용되며 종종 새로운 리소스를 만드는 데 사용됩니다. 3. PUT 방법은 리소스를 업데이트하는 데 사용되며 완전한 업데이트에 적합합니다. 4. 삭제 방법은 자원을 삭제하는 데 사용되며 삭제 작업에 적합합니다.

PHP에서 Password_hash 및 Password_Verify 기능을 사용하여 보안 비밀번호 해싱을 구현해야하며 MD5 또는 SHA1을 사용해서는 안됩니다. 1) Password_hash는 보안을 향상시키기 위해 소금 값이 포함 된 해시를 생성합니다. 2) Password_verify 암호를 확인하고 해시 값을 비교하여 보안을 보장합니다. 3) MD5 및 SHA1은 취약하고 소금 값이 부족하며 현대 암호 보안에는 적합하지 않습니다.

PHP는 서버 측에서 널리 사용되는 스크립팅 언어이며 특히 웹 개발에 적합합니다. 1.PHP는 HTML을 포함하고 HTTP 요청 및 응답을 처리 할 수 있으며 다양한 데이터베이스를 지원할 수 있습니다. 2.PHP는 강력한 커뮤니티 지원 및 오픈 소스 리소스를 통해 동적 웹 컨텐츠, 프로세스 양식 데이터, 액세스 데이터베이스 등을 생성하는 데 사용됩니다. 3. PHP는 해석 된 언어이며, 실행 프로세스에는 어휘 분석, 문법 분석, 편집 및 실행이 포함됩니다. 4. PHP는 사용자 등록 시스템과 같은 고급 응용 프로그램을 위해 MySQL과 결합 할 수 있습니다. 5. PHP를 디버깅 할 때 error_reporting () 및 var_dump ()와 같은 함수를 사용할 수 있습니다. 6. 캐싱 메커니즘을 사용하여 PHP 코드를 최적화하고 데이터베이스 쿼리를 최적화하며 내장 기능을 사용하십시오. 7

PHP는 전자 상거래, 컨텐츠 관리 시스템 및 API 개발에 널리 사용됩니다. 1) 전자 상거래 : 쇼핑 카트 기능 및 지불 처리에 사용됩니다. 2) 컨텐츠 관리 시스템 : 동적 컨텐츠 생성 및 사용자 관리에 사용됩니다. 3) API 개발 : 편안한 API 개발 및 API 보안에 사용됩니다. 성능 최적화 및 모범 사례를 통해 PHP 애플리케이션의 효율성과 유지 보수 성이 향상됩니다.

화살표 기능은 PHP7.4에 도입되었으며 단순화 된 형태의 짧은 폐쇄입니다. 1) => 연산자를 사용하여 정의되어 기능을 생략하고 키워드를 사용합니다. 2) 화살표 기능은 사용 키워드없이 현재 스코프 변수를 자동으로 캡처합니다. 3) 종종 코드 단순성과 가독성을 향상시키기 위해 콜백 기능 및 짧은 계산에 사용됩니다.
