이벤트
1. 이벤트는 더 자세한 비즈니스 시나리오를 더 정확하게 찾을 수 있다는 점을 제외하면 미들웨어와 약간 유사합니다.
2 이벤트 클래스, 이벤트 청취 클래스, 이벤트 구독 클래스를 정의할 수 있습니다. 3. 먼저 테스트 이벤트 클래스를 만듭니다. TestEvent.php, 수동으로 테스트 클래스를 만듭니다.
public function __construct() { //注册监听器 Event::listen('TestListen', function ($param) { echo '我是监听器,我被触发了!'.$param; }); } public function info() { echo '登录前准备!'; Event::trigger('TestListen', 'ok'); //触发监听器 event('TestListen'); //助手函数触发 }
4. 또한 청취 클래스를 사용하여 명령줄을 사용하여 생성할 수도 있습니다. app/ event.php에서 Listen은 청취 클래스를 구성합니다.
php think make:listener TestListen
6. 청취 클래스가 트리거되면 자동으로 handler() 메소드가 실행되어 청취 기능을 구현합니다. 7. 시스템에도 내장된 시스템이 트리거됩니다. 조건이 충족되는 한 이벤트가 자동으로 트리거됩니다.
이벤트 설명 매개변수 AppInit 애플리케이션 초기화 태그 비트 없음 HttpRun 애플리케이션 시작 태그 비트 없음 HttpEnd 애플리케이션 종료 태그 비트 현재 응답 객체 인스턴스 LogWrite 로그 쓰기 메소드 태그 비트 현재 작성된 로그 정보 RouteLoaded 경로 로딩이 완료되었습니다. 8. 이벤트 청취 클래스는 식별자에 바인딩되어 있는 한 동시에 여러 청취 클래스를 모니터링할 수 있습니다.public function info() { echo '登录前准备!'; Event::listen('TestListen', TestListen::class); //这句可以定义到配置文件 Event::trigger('TestListen'); }
9. 다중 모니터링이 필요한 경우 청취 클래스가 충분히 생성되지 않으므로 구독 클래스를 사용할 수 있습니다.
10 구독 클래스는 청취 이벤트를 내부 방법으로 사용하는 것입니다. on+method name을 구현하려면'listen' => [ 'TestListen' => [\app\listener\TestListen::class] ],
public function handle($event) { echo '我是监听类!'.$event; }
'TestListen' => [ \app\listener\TestListen::class, \app\listener\TestOne::class, \app\listener\TestTwo::class ]
php think make:subscribe UserSub class UserSub { public function onUserLogin(){ echo '处理登录后的监听!'; } public function onUserLogout(){ echo '处理退出后的监听!'; } }
'subscribe' => [ 'UserSub' => \app\subscribe\UserSub::class, ],
다중 애플리케이션 이후. mode는 확장이므로 추가로 설치해야 합니다.
public function login(){ echo '登录成功!'; Event::trigger('UserLogin'); } public function logout(){ echo '退出成功!'; Event::trigger('UserLogout'); }
2. 설치 후 index와 admin이라는 두 개의 응용 프로그램 디렉터리 폴더를 만듭니다.
3. 컨트롤러를 모델로 이동하고 해당 네임스페이스를 수정하기만 하면 됩니다.
4. 두 개의 애플리케이션 디렉토리 폴더인 index와 admin을 뷰에 추가하고 해당 폴더로 이동합니다. 5. 기본 애플리케이션은 index입니다. 그게 전부입니다.
php think make:event UserEvent
6. admin 디렉터리를 매핑하여 관리자를 삭제하는 등 애플리케이션 매핑을 수행할 수 있습니다;
class UserEvent { public function __construct() { echo '我是事件类!'; } } Event::trigger(new UserEvent());
7. 예를 들어 직접 액세스를 위해 백그라운드에서 도메인 이름 바인딩을 사용하는 등 도메인 이름 바인딩도 수행할 수 있습니다.
composer require topthink/think-multi-app
8. 경로 수정: 경로는 애플리케이션 디렉토리에서 별도로 설정해야 하며 내부 코딩은 변경할 필요가 없습니다.
추천 튜토리얼: "
ThinkPHP Tutorial"
위 내용은 ThinkPHP6 이벤트 및 다중 애플리케이션의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!