


Comprendre la série de conteneurs d'injection de dépendances PHP (2) Ce dont vous avez besoin
Dec 28, 2016 am 10:24 AMDans l'article précédent, nous avons utilisé un cas Web spécifique pour illustrer l'injection de dépendances. Aujourd'hui, nous allons parler du conteneur d'injection de dépendances (Container). Commen?ons par une déclaration importante?:
Big Most of. le moment où vous utilisez l’injection de dépendances pour découpler les composants, vous n’avez pas besoin de conteneur.
Mais si vous souhaitez gérer de nombreux objets différents et gérer des dépendances complexes entre objets, les conteneurs deviennent très utiles.
Vous vous souvenez de l'exemple du premier article?? Avant de créer un objet User, vous devez d'abord créer un objet SessionStorage. Ce n'est pas grave, mais je tiens quand même à dire que c'est parce que vous connaissez clairement les objets dont il dépend avant de créer l'objet dont vous avez besoin. S'il y a beaucoup d'objets et que les dépendances sont compliquées (en supposant que la classe SessionStorage dépend de la classe cache, la classe cache dépend de la classe file et de la classe inputFilter, et la classe file dépend de la classe stdio), alors c'est un problème . . . .
$storage = new SessionStorage('SESSION_ID'); $user = new User($storage);
Dans les articles suivants, nous présenterons comment implémenter des conteneurs dans Symfony 2. Mais pour l’instant, afin d’expliquer les conteneurs de manière simple et claire, nous ignorerons Symfony pour l’instant. Ce qui suit utilisera un exemple dans Zend Framework pour illustrer?:
La classe Zend_Mail de Zend Framework simplifie la gestion des e-mails. Elle utilise la fonction mail() de PHP pour envoyer des e-mails par défaut, mais sa flexibilité n'est pas bonne. Heureusement, ce comportement peut être facilement modifié en fournissant une classe de transport.
Le code suivant montre comment créer la classe Zend_Mail et utiliser un compte Gmail pour envoyer des e-mails.
$transport = new Zend_Mail_Transport_Smtp('smtp.gmail.com', array( 'auth' => 'login', 'username' => 'foo', 'password' => 'bar', 'ssl' => 'ssl', 'port' => 465, )); $mailer = new Zend_Mail(); $mailer->setDefaultTransport($transport);
Le conteneur d'injection de dépendances est une grande classe qui peut instancier et configurer divers éléments qu'il gère. cours. Pour pouvoir faire cela, il doit conna?tre les paramètres et dépendances des méthodes constructeur de ces classes.
Ce qui suit est un conteneur codé en dur, qui implémente toujours le travail d'obtention de l'objet Zend_Mail mentionné précédemment?:
class Container { public function getMailTransport() { return new Zend_Mail_Transport_Smtp('smtp.gmail.com', array( 'auth' => 'login', 'username' => 'foo', 'password' => 'bar', 'ssl' => 'ssl', 'port' => 465, )); } public function getMailer() { $mailer = new Zend_Mail(); $mailer->setDefaultTransport($this->getMailTransport()); return $mailer; } } //容器的使用也很簡(jiǎn)單 $container = new Container(); $mailer = $container->getMailer();
Lors de l'utilisation du conteneur, si vous avez besoin d'obtenir un objet Zend_Mail, ne Vous devez conna?tre les détails de sa création, car tous les détails de la création d'une instance d'objet sont intégrés au conteneur. La dépendance de Zend_Mail sur la classe Mail_Transport peut également être automatiquement injectée dans l'objet Zend_Mail via le conteneur.
L'obtention d'objets dépendants est principalement implémentée par getMailTransport(). La puissance du conteneur est obtenue par ce simple appel get.
Mais si vous êtes intelligent, vous devez avoir découvert le problème. Il y a du codage en dur dans le conteneur (comme les informations de compte et de mot de passe pour l'envoi d'e-mails, etc.). Nous devons donc aller plus loin et ajouter des paramètres au conteneur pour rendre le conteneur plus utile.
class Container { protected $parameters = array(); public function __construct(array $parameters = array()) { $this->parameters = $parameters; } public function getMailTransport() { return new Zend_Mail_Transport_Smtp('smtp.gmail.com', array( 'auth' => 'login', 'username' => $this->parameters['mailer.username'], 'password' => $this->parameters['mailer.password'], 'ssl' => 'ssl', 'port' => 465, )); } public function getMailer() { $mailer = new Zend_Mail(); $mailer->setDefaultTransport($this->getMailTransport()); return $mailer; } }
Vous pouvez désormais facilement changer de compte et de mot de passe pour l'envoi d'e-mails via les paramètres du constructeur de conteneur
$container = new Container(array( 'mailer.username' => 'foo', 'mailer.password' => 'bar', )); $mailer = $container->getMailer();
Si vous estimez que la classe Zend_Mail ne peut pas répondre aux besoins actuels ( comme lors des tests, vous devez faire quelques journaux), si vous souhaitez changer facilement de classe d'envoi de courrier, vous pouvez également transmettre le nom de la classe via les paramètres du constructeur du conteneur
class Container { // ... public function getMailer() { $class = $this->parameters['mailer.class']; $mailer = new $class(); $mailer->setDefaultTransport($this->getMailTransport()); return $mailer; } } $container = new Container(array( 'mailer.username' => 'foo', 'mailer.password' => 'bar', 'mailer.class' => 'MyTest_Mail', )); $mailer = $container->getMailer();
Enfin, en considérant que les clients n'ont pas besoin de ré-instancier à chaque fois lors de l'obtention de l'objet mailer (surcharge), le conteneur doit fournir la même instance d'objet à chaque fois.
Par conséquent, le programme utilise le tableau statique protégé $shared pour stocker le premier objet instancié. à l'avenir, lorsque l'utilisateur obtiendra le mailer, le premier objet instancié sera renvoyé
class Container { static protected $shared = array(); // ... public function getMailer() { if (isset(self::$shared['mailer'])) { return self::$shared['mailer']; } $class = $this->parameters['mailer.class']; $mailer = new $class(); $mailer->setDefaultTransport($this->getMailTransport()); return self::$shared['mailer'] = $mailer; } }
Les conteneurs sont encapsulés. ces fonctions de base. Ce que le conteneur doit gérer inclut l’instanciation et la configuration des objets. Ces objets eux-mêmes ne savent pas qu'ils sont gérés par le conteneur et peuvent ignorer l'existence du conteneur. C'est pourquoi le conteneur peut gérer n'importe quelle classe PHP. Il serait préférable que l'objet lui-même utilise l'injection de dépendances pour gérer les dépendances, mais bien s?r, cela n'est pas nécessaire.
Mais créer et entretenir des contenants à la main peut vite devenir un cauchemar. L'article suivant décrira comment Symfony 2 implémente les conteneurs.
Ce qui précède est ce dont vous avez besoin pour comprendre la série de conteneurs d'injection de dépendances PHP (2). Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois (www.miracleart.cn)?!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

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.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

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)

Sujets chauds

La mise à niveau de la version PHP n'est en fait pas difficile, mais la clé réside dans les étapes de fonctionnement et les précautions. Voici les méthodes spécifiques: 1. Confirmez la version PHP actuelle et l'environnement d'exécution, utilisez la ligne de commande ou le fichier phpinfo.php à afficher; 2. Sélectionnez la nouvelle version appropriée et installez-la. Il est recommandé de l'installer avec 8,2 ou 8,1. Les utilisateurs de Linux utilisent Package Manager et les utilisateurs de MacOS utilisent Homebrew; 3. Migrer les fichiers de configuration et les extensions, mettre à jour PHP.ini et installer les extensions nécessaires; 4. Testez si le site Web s'exécute normalement, vérifiez le journal des erreurs pour vous assurer qu'il n'y a pas de problème de compatibilité. Suivez ces étapes et vous pouvez terminer avec succès la mise à niveau dans la plupart des situations.

TopreventcsrfattackSinPhp, implémentanti-csrftokens.1) GenerateAndStoreSecureToKensusingRandom_Bytes () Orbin2hex (Random_Bytes (32)), Savethemin $ _Session, et inclusetheminglycombaringthepostthentikwishswe

Pour configurer un environnement de développement PHP, vous devez sélectionner les outils appropriés et installer correctement la configuration. ① L'environnement local PHP le plus basique nécessite trois composants: le serveur Web (Apache ou Nginx), le PHP lui-même et la base de données (comme MySQL / MARIADB); ② Il est recommandé que les débutants utilisent des packages d'intégration tels que XAMPP ou MAMP, ce qui simplifie le processus d'installation. XAMPP convient aux fenêtres et aux macOS. Après l'installation, les fichiers du projet sont placés dans le répertoire HTDOCS et accessibles via LocalHost; ③Mamp convient aux utilisateurs Mac et prend en charge la commutation pratique des versions PHP, mais la version gratuite a des fonctions limitées; ④ Les utilisateurs avancés peuvent les installer manuellement par Homebrew, dans les systèmes MacOS / Linux

Pour fusionner deux tableaux PHP et conserver des valeurs uniques, il existe deux méthodes principales. 1. Pour les réseaux d'index ou uniquement la déduplication, utilisez Array_merge et Array_Unique Combinaisons: First Merge Array_merge ($ array1, $ array2), puis utilisez Array_Unique () pour les dédupliquer pour enfin obtenir un nouveau tableau contenant toutes les valeurs uniques; 2. Pour les tableaux associatifs et souhaitez conserver les paires de valeurs clés dans le premier tableau, utilisez l'opérateur: $ result = $ array1 $ array2, ce qui garantira que les clés du premier tableau ne seront pas écrasées par le deuxième tableau. Ces deux méthodes s'appliquent à des scénarios différents, selon que le nom de clé est conservé ou que l'accent est mis sur

Exit () est une fonction de PHP qui est utilisée pour terminer l'exécution du script immédiatement. Les utilisations courantes incluent: 1. Terminez le script à l'avance lorsqu'une exception est détectée, comme le fichier n'existe pas ou que la vérification échoue; 2. Résultats intermédiaires de sortie pendant le débogage et l'arrêt de l'exécution; 3. Appelez Exit () après la redirection en conjonction avec Header () pour empêcher l'exécution de code ultérieure; De plus, Out () peut accepter les paramètres de cha?ne en tant que contenu de sortie ou entiers comme code d'état, et son alias est DIE ().

L'utilisation rationnelle des balises sémantiques dans HTML peut améliorer la clarté de la structure des pages, l'accessibilité et les effets SEO. 1. Utilisé pour des blocs de contenu indépendants, tels que des articles de blog ou des commentaires, il doit être autonome; 2. Utilisé pour le contenu lié à la classification, incluant généralement des titres, et convient à différents modules de la page; 3. Utilisé pour les informations auxiliaires liées au contenu principal mais pas au c?ur, telles que les recommandations de barres latérales ou les profils d'auteur. Dans le développement réel, les étiquettes doivent être combinées et autres, éviter une nidification excessive, garder la structure simple et vérifier la rationalité de la structure via les outils du développeur.

Pour accéder aux données de la session dans PHP, vous devez d'abord démarrer la session, puis fonctionner via le tableau hyperglobal $ _Session. 1. La session doit être démarrée à l'aide de session_start (), et la fonction doit être appelée avant toute sortie; 2. Lorsque vous accédez aux données de session, vérifiez si la clé existe. Vous pouvez utiliser isset ($ _ session ['key']) ou array_key_exists ('key', $ _ session); 3. Définir ou mettre à jour les variables de session doivent seulement attribuer des valeurs au tableau $ _Session sans enregistrer manuellement; 4. Effacer des données spécifiques avec unset ($ _ session ['key']), effacez toutes les données et définissez $ _Session sur un tableau vide.

Les fonctions récursives se réfèrent aux fonctions de l'auto-entour dans PHP. Les éléments centraux sont 1. Définition des conditions de terminaison (exemples de base), 2. Décomposant le problème et s'appelant récursivement (exemples récursifs). Il convient à la gestion des structures hiérarchiques, à la démonstration de sous-problèmes en double ou à l'amélioration de la lisibilité du code, tel que le calcul de la factorielle, la traversée des répertoires, etc. Cependant, il est nécessaire de prêter attention aux risques de consommation de mémoire et de débordement de pile. Lors de l'écriture, les conditions de sortie doivent être clarifiées, les exemples de base doivent être progressivement approchés, les paramètres redondants doivent être évités et de petites entrées doivent être testées. Par exemple, lors de la numérisation d'un répertoire, la fonction rencontre un sous-répertoire et s'appelle récursivement jusqu'à ce que tous les niveaux soient traversés.
