Événements
1. Les événements sont quelque peu similaires au middleware, sauf que les événements peuvent localiser plus précisément des scénarios commerciaux plus détaillés
2. classe d'événement, classe d'écoute d'événement, classe d'abonnement à un événement ;
3. Nous créons d'abord une classe d'événement de test : TestEvent.php, et créons manuellement une classe de test
public function __construct() { //注册监听器 Event::listen('TestListen', function ($param) { echo '我是监听器,我被触发了!'.$param; }); } public function info() { echo '登录前准备!'; Event::trigger('TestListen', 'ok'); //触发监听器 event('TestListen'); //助手函数触发 }
4. peut utiliser la classe d'écoute pour concevoir un écouteur et le créer à l'aide de la ligne de commande ;
php think make:listener TestListen
public function info() { echo '登录前准备!'; Event::listen('TestListen', TestListen::class); //这句可以定义到配置文件 Event::trigger('TestListen'); }
5. Dans app/event.php, Listen est configuré pour écouter la classe d'écoute.
'listen' => [ 'TestListen' => [\app\listener\TestListen::class] ],
6 . Lorsque la classe de surveillance est déclenchée, elle exécutera automatiquement la méthode handle() pour implémenter la fonction de surveillance
public function handle($event) { echo '我是监听类!'.$event; }
7. événements, qui se déclencheront automatiquement tant que les conditions sont remplies ;
Paramètres de description de l'événement Bit de balise d'initialisation de l'application AppInit Aucun Bit de balise de début d'application HttpRun Aucun Bit de balise de fin d'application HttpEnd Actuel instance d'objet de réponse LogWrite Méthode d'écriture du journal bit de balise Informations de journal actuellement écrites RouteLoaded Chargement de la route terminé Aucun
8 La classe d'écoute d'événements peut surveiller plusieurs classes d'écoute en même temps, à condition qu'elle soit liée à un identifiant ;
'TestListen' => [ \app\listener\TestListen::class, \app\listener\TestOne::class, \app\listener\TestTwo::class ]
9. Pour ceux qui ont besoin de plusieurs monitorings, le cours d'écoute n'est pas assez flexible et il y aura beaucoup de cours créés, vous pouvez utiliser le cours sur abonnement
10. la classe d'abonnement consiste à utiliser l'événement d'écoute comme méthode interne pour implémenter on+method name;
php think make:subscribe UserSub class UserSub { public function onUserLogin(){ echo '处理登录后的监听!'; } public function onUserLogout(){ echo '处理退出后的监听!'; } }
11. Ensuite, nous allons directement dans app/event.php
'subscribe' => [ 'UserSub' => \app\subscribe\UserSub::class, ],
12. Ensuite, les deux méthodes écoutent respectivement deux méthodes d'événement, il suffit d'appeler directement le nom de la méthode
public function login(){ echo '登录成功!'; Event::trigger('UserLogin'); } public function logout(){ echo '退出成功!'; Event::trigger('UserLogout'); }
13. le système fournit de nombreuses solutions précises ;
php think make:event UserEvent
class UserEvent { public function __construct() { echo '我是事件类!'; } } Event::trigger(new UserEvent());
Mode multi-application
1 Étant donné que le mode multi-application est une extension, nous avons besoin d'une installation supplémentaire
composer require topthink/think-multi-app
2. Après l'installation, créez deux dossiers de répertoire d'application, index et admin ;
3. Déplacez simplement le contrôleur et le modèle et modifiez l'espace de noms correspondant ;
4. dossiers du répertoire, index et admin, vers la vue et déplacez-les dans les dossiers correspondants ;
5 L'application par défaut est index, modifiez-la simplement dans app.php
// 默认应用 'default_app' => 'index',
6. peut faire un mappage d'application, comme mapper le répertoire admin pour penser, et l'administrateur est abandonné
// 应用映射(自动多应用模式有效) 'app_map' => [ 'think' => 'admin' ],
7 Nous pouvons également faire une liaison de nom de domaine, par exemple, en utilisant la liaison de nom de domaine en arrière-plan, Accès direct ;
// 域名绑定(自动多应用模式有效) 'domain_bind' => [ 'news.abc.com' => 'admin', '*' => 'index' ],
8. Modification de la route : la route doit être établie séparément dans le répertoire de l'application et le codage interne n'a pas besoin d'être modifié
Tutoriel recommandé : "Tutoriel ThinkPHP ; "
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!