


Analyse connexe des conteneurs de services et de l'injection de dépendances en PHP
Injection de dépendances
Lorsque la classe A doit dépendre de la classe B, c'est-à-dire que la classe B doit être instanciée dans la classe A Lorsqu'un objet est utilisé, si les fonctions de la classe B changent, les endroits où la classe B est utilisée dans la classe A seront également modifiés, ce qui entraînera un couplage élevé entre la classe A et la classe B. La solution à l'heure actuelle est que la classe A s'appuie sur l'interface de la classe B et confie l'instanciation de classes spécifiques à l'extérieur.
Prenons comme exemple le module de notification couramment utilisé dans notre métier.
Général
<?php /** * 定义了一个消息类 * Class Message */ class Message{ public function seed() { return '灰太狼准备吃羊'; } } /* * 订单产生的时候 需要发送消息 */ class Order{ protected $messager = ''; function __construct() { $this->messager = new Message(); } public function seed_msg() { return $this->messager->seed(); } } $Order = new Order(); echo $Order->seed_msg();
Le code ci-dessus est notre manière traditionnelle d'écrire. Tout d'abord, la classe envoyée par le message. Ensuite, là où nous devons envoyer un message, appelez l'interface d'envoi du message. Un jour, vous devrez ajouter une interface d'envoi de messages texte pour répondre à différents besoins. Ensuite, vous constaterez que vous devez apporter des modifications à la classe Message. Vous devez également apporter des modifications dans la classe Order. Cela semble très gênant. A cette époque, l’idée de l’injection de dépendances est née.
L'idée de s'appuyer sur l'injection
<?php /** * 为了约束我们先定义一个消息接口 * Interface Message */ interface Message{ public function seed(); } /** * 有一个发送邮件的类 * Class SeedEmail */ class SeedEmail implements Message { public function seed() { return '灰太狼发邮件给红太狼说要吃烤全羊'; } } /** *新增一个发送短信的类 * Class SeedSMS */ class SeedSMS implements Message { public function seed() { return '灰太狼发短信给红太狼说要吃烤全羊'; } } /* * 订单产生的时候 需要发送消息 */ class Order{ protected $messager = ''; function __construct(Message $message) { $this->messager = $message; } public function seed_msg() { return $this->messager->seed(); } } //我们需要发送邮件的时候 $message = new SeedEmail(); //将邮件发送对象作为参数传递给Order $Order = new Order($message); echo $Order->seed_msg(); echo "\n"; //我们需要发送短信的时候 $message = new SeedSMS(); $Order = new Order($message); echo $Order->seed_msg();
Le conteneur de service que je comprends est une usine qui génère automatiquement des classes.
Conteneur de service
<?php /** * 为了约束我们先定义一个消息接口 * Interface Message */ interface Message{ public function seed(); } /** * 有一个发送邮件的类 * Class SeedEmail */ class SeedEmail implements Message { public function seed() { return '灰太狼发邮件给红太狼说要吃烤全羊'; } } /** *新增一个发送短信的类 * Class SeedSMS */ class SeedSMS implements Message { public function seed() { return '灰太狼发短信给红太狼说要吃烤全羊'; } } /** * 这是一个简单的服务容器 * Class Container */ class Container { protected $binds; protected $instances; public function bind($abstract, $concrete) { if ($concrete instanceof Closure) { $this->binds[$abstract] = $concrete; } else { $this->instances[$abstract] = $concrete; } } public function make($abstract, $parameters = []) { if (isset($this->instances[$abstract])) { return $this->instances[$abstract]; } array_unshift($parameters, $this); return call_user_func_array($this->binds[$abstract], $parameters); } } //创建一个消息工厂 $message = new Container(); //将发送短信注册绑定到工厂里面 $message->bind('SMS',function (){ return new SeedSMS(); }); //将发送邮件注册绑定到工厂 $message->bind('EMAIL',function (){ return new SeedEmail(); }); //需要发送短信的时候 $SMS = $message->make('SMS'); echo $SMS->seed(); echo "\n"; $EMAIL = $message->make('EMAIL'); echo $EMAIL->seed();
le conteneur est un conteneur de service simple qui contient bind,make Deux méthodes
bind consistent à lier l'objet de service au conteneur.
make prend l'objet du conteneur.
bind
Dans la méthode bind, vous devez transmettre un objet concret. Nous pouvons transmettre un objet instance ou une fonction de fermeture.
Vous pouvez voir que j'utilise une fonction de fermeture. En fait, vous pouvez aussi l'écrire comme ceci
$sms = new SeedSMS(); $message->bind('SMS',$sms);
La différence entre cette dernière méthode d'écriture et la fermeture est que nous devons d'abord instancier l'objet avant. nous pouvons procéder facilement. Les fermetures instancient uniquement les objets lorsque nous utilisons ce service. On constate que les fermetures présentent de nombreux avantages.
make
La méthode make est la méthode hors du conteneur. Il détermine d'abord s'il existe un objet de service actuel et existant dans la variable instances et, si c'est le cas, le renvoie directement. Sinon, un objet sera renvoyé via call_user_func_array. L'utilisation de call_user_func_array peut être consultée dans
Utilisation de call_user_func en PHP
Pour plus d'articles techniques liés à PHP, veuillez visiter Tutoriel PHPChronique pour apprendre !
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Pour travailler avec la date et l'heure dans cakephp4, nous allons utiliser la classe FrozenTime disponible.

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

Le validateur peut être créé en ajoutant les deux lignes suivantes dans le contrôleur.

Se connecter à CakePHP est une tâche très simple. Il vous suffit d'utiliser une seule fonction. Vous pouvez enregistrer les erreurs, les exceptions, les activités des utilisateurs, les actions entreprises par les utilisateurs, pour tout processus en arrière-plan comme cronjob. La journalisation des données dans CakePHP est facile. La fonction log() est fournie

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

CakePHP est un framework MVC open source. Cela facilite grandement le développement, le déploiement et la maintenance des applications. CakePHP dispose d'un certain nombre de bibliothèques pour réduire la surcharge des tâches les plus courantes.
