Maison > cadre php > PensezPHP > Événements ThinkPHP6 et applications multiples

Événements ThinkPHP6 et applications multiples

Guanhui
Libérer: 2020-05-08 10:29:06
avant
4058 Les gens l'ont consulté

É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'); //助手函数触发
}
Copier après la connexion

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
Copier après la connexion
public function info()
{
echo '登录前准备!';
Event::listen('TestListen', TestListen::class); //这句可以定义到配置文件
Event::trigger('TestListen');
}
Copier après la connexion

5. Dans app/event.php, Listen est configuré pour écouter la classe d'écoute.

'listen' => [
'TestListen' => [\app\listener\TestListen::class]
],
Copier après la connexion

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;
}
Copier après la connexion

7. événements, qui se déclencheront automatiquement tant que les conditions sont remplies ;

Événements ThinkPHP6 et applications multiples

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
]
Copier après la connexion

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 '处理退出后的监听!';
}
}
Copier après la connexion

11. Ensuite, nous allons directement dans app/event.php

'subscribe' => [
'UserSub' => \app\subscribe\UserSub::class,
],
Copier après la connexion

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');
}
Copier après la connexion

13. le système fournit de nombreuses solutions précises ;

php think make:event UserEvent
Copier après la connexion
class UserEvent
{
public function __construct()
{
echo '我是事件类!';
}
}
Event::trigger(new UserEvent());
Copier après la connexion

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
Copier après la connexion
 ;

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',
Copier après la connexion

6. peut faire un mappage d'application, comme mapper le répertoire admin pour penser, et l'administrateur est abandonné

// 应用映射(自动多应用模式有效)
'app_map' => [
'think' => 'admin'
],
Copier après la connexion

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'
],
Copier après la connexion

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!

Étiquettes associées:
source:zhihu.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal