Comprendre la série de conteneurs d'injection de dépendances PHP (3) Symfony
Dec 28, 2016 am 10:27 AMJusqu'à présent, nous avons parlé de quelques concepts de base. Les exemples des deux premiers articles nous sont très utiles pour comprendre l'implémentation de l'injection de dépendances. Nous allons maintenant approfondir l'implémentation du conteneur de services Symfony 2.
Le conteneur d'injection de dépendances dans Symfony est géré par une classe appelée sfServiceContainer
Le conteneur Symfony peut exister en tant que composant indépendant Le référentiel Subversion officiel de Symfony peut être téléchargé?: http://svn .symfony-. project.com/components/dependency_injection/trunk/
. Il convient de noter que ce composant est toujours en développement itératif continu, il peut donc être mis à jour à tout moment (cela a été dit en 2009, mais cela semble s'être arrêté maintenant).
Selon la philosophie de conception de Symfony, tout service peut être un objet géré par un conteneur. Dans l'exemple Zend_Mail présenté dans l'article précédent, il y a deux objets : mailer et mail_transport
class Container { static protected $shared = array(); 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() { 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; } }
Si la classe Container hérite de la classe sfServiceContainer de Symfony, le code peut être un peu plus simple
class Container extends sfServiceContainer { static protected $shared = array(); protected function getMailTransportService() { return new Zend_Mail_Transport_Smtp('smtp.gmail.com', array( 'auth' => 'login', 'username' => $this['mailer.username'], 'password' => $this['mailer.password'], 'ssl' => 'ssl', 'port' => 465, )); } protected function getMailerService() { if (isset(self::$shared['mailer'])) { return self::$shared['mailer']; } $class = $this['mailer.class']; $mailer = new $class(); $mailer->setDefaultTransport($this->getMailTransportService()); return self::$shared['mailer'] = $mailer; } }
Par observation?: Le code de gestion de la configuration du constructeur et des paramètres est omis.
Mais ce n'est pas tout. sfServiceContainer peut nous offrir une interface puissante et concise. Voici quelques points à prendre en compte lors de l'utilisation de l'interface?:
1. Service. Habituellement, nous convenons que le nom de la méthode commence par get et se termine par Service. Chaque service possède un logo unique. Le logo est généralement le nom de la méthode sans le suffixe et le suffixe, séparés par des traits de soulignement. Si la méthode getMailTransportService() est définie, le nom du service est mail_transport
2. La méthode est de type protégé, ce qui signifie que vous ne pouvez pas appeler directement la méthode pour obtenir le service. Nous présenterons plus tard comment utiliser les conteneurs pour obtenir des services.
3. Le conteneur est accessible sous forme de tableau pour obtenir les paramètres transmis. Par exemple : $this['mailer.class']
La marque de service doit être unique et ne peut être composée que de lettres, de chiffres, de ? _ ? et de ? . ?. '.' peut être utilisé comme espace de noms (comme mail.mailer et mail.transport).
Voyons maintenant comment utiliser ce nouveau conteneur
require_once 'PATH/TO/sf/lib/sfServiceContainerAutoloader.php'; sfServiceContainerAutoloader::register(); $sc = new Container(array( 'mailer.username' => 'foo', 'mailer.password' => 'bar', 'mailer.class' => 'Zend_Mail', )); $mailer = $sc->mailer;
Comme la classe Container hérite de sfServiceContainer, l'interface devient très soignée.
Le service est accessible via l'interface unifiée
if ($sc->hasService('mailer')) { $mailer = $sc->getService('mailer'); } $sc->setService('mailer', $mailer);
Un moyen plus simple est d'accéder au service via les attributs
if (isset($sc->mailer)) { $mailer = $sc->mailer; } $sc->mailer = $mailer;Les paramètres sont accessibles via l'interface unifiée interface
if (!$sc->hasParameter('mailer_class')) { $sc->setParameter('mailer_class', 'Zend_Mail'); } echo $sc->getParameter('mailer_class'); // Override all parameters of the container $sc->setParameters($parameters); // Adds parameters $sc->addParameters($parameters);
Les paramètres sont également accessibles comme des tableaux via des conteneurs
if (!isset($sc['mailer.class'])) { $sc['mailer.class'] = 'Zend_Mail'; } $mailerClass = $sc['mailer.class'];
Les conteneurs peuvent être considérés comme des itérateurs pour parcourir tous les services
foreach ($sc as $id => $service) { echo sprintf("Service %s is an instance of %s.\n", $id, get_class($service)); }
S'il n'y a pas beaucoup de services à gérer, même s'il faut quand même faire beaucoup de travail de base et copier beaucoup de code, il faut admettre qu'utiliser sfServiceContainer est très utile.
Si le nombre de services à gérer augmente de plus en plus, il doit y avoir une meilleure fa?on de décrire les services.
C'est pourquoi la plupart du temps, nous n'utilisons pas directement la classe sfServiceContainer. Il est néanmoins nécessaire de consacrer un peu de temps à en parler, car il s'agit d'une pierre angulaire importante du conteneur d'injection de dépendances de Symfony.
Ce qui précède est le contenu de la compréhension de la série de conteneurs d'injection de dépendances PHP (3) Symfony Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois (ipnx.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





Dans JavaScript, vous devez utiliser une fonction personnalisée pour déterminer si deux tableaux sont égaux, car il n'y a pas de méthode intégrée. 1) L'implémentation de base consiste à comparer les longueurs et les éléments, mais ne peut pas traiter les objets et les tableaux. 2) La comparaison de la profondeur récursive peut gérer les structures imbriquées, mais nécessite un traitement spécial de NAN. 3) Les types spéciaux tels que les fonctions et les dates doivent être pris en compte, et une optimisation et des tests supplémentaires sont nécessaires.

La vérification du numéro de sécurité sociale est mise en ?uvre en PHP par des expressions régulières et une logique simple. 1) Utilisez des expressions régulières pour nettoyer l'entrée et supprimer les caractères non nucères. 2) Vérifiez si la longueur de la cha?ne est de 18 bits. 3) Calculez et vérifiez le bit de contr?le pour s'assurer qu'il correspond au dernier bit de l'entrée.

Les méthodes pour gérer correctement ce pointage dans les fermetures JavaScript incluent: 1. Utilisez les fonctions de flèche, 2. Utilisez des méthodes de liaison, 3. Utilisez des variables pour enregistrer cela. Ces méthodes garantissent que cette fonction intrinsèque pointe correctement le contexte de la fonction externe.

L'utilisation de JavaScript pour implémenter le chiffrement des données peut utiliser la bibliothèque Crypto-JS. 1. Installez et introduisez la bibliothèque Crypto-JS. 2. Utilisez l'algorithme AES pour le cryptage et le déchiffrement pour vous assurer que la même clé est utilisée. 3. Faites attention au stockage sécurisé et à la transmission des clés. Il est recommandé d'utiliser le mode CBC et les variables d'environnement pour stocker les clés. 4. Envisagez d'utiliser des travailleurs Web lorsque vous avez besoin de performances élevées. 5. Lors du traitement des caractères non ASCII, vous devez spécifier la méthode de codage.

Dans PHP, le constructeur est défini par la méthode de magie \ _ \ _ \ _. 1) Définissez la méthode de construction \ _ \ _ dans la classe, qui sera automatiquement appelée lorsque l'objet est instancié et est utilisé pour initialiser les propriétés de l'objet. 2) Le constructeur peut accepter n'importe quel nombre de paramètres et initialiser de manière flexible l'objet. 3) Lorsque vous définissez un constructeur dans une sous-classe, vous devez appeler Parent :: \ _ \ _ Construct () pour vous assurer que le constructeur de classe parent s'exécute. 4) Grace aux paramètres et aux conditions facultatifs du jugement, le constructeur peut simuler l'effet de surcharge. 5) Le constructeur doit être concis et seule l'initialisation nécessaire doit être effectuée pour éviter les opérations de logique ou d'E / S complexe.

Les étapes pour déployer un site Web Joomla sur PHPStudy incluent: 1) Configurer PHPStudy, s'assurer que les services Apache et MySQL s'exécutent et vérifient la compatibilité de la version PHP; 2) Télécharger et décompresser le site Web de PHPStudy du site officiel de Joomla au répertoire racine de PHPStudy, puis compléter l'installation via le navigateur selon l'assistant d'installation; 3) Faire des configurations de base, telles que la définition du nom du site Web et l'ajout de contenu.

Les avantages de l'utilisation de l'injection de dépendance (DI) en PHP comprennent: 1. Découplage, rendant le code plus modulaire; 2. Améliorer la testabilité et les simulations ou les talons faciles à utiliser; 3. Augmenter la flexibilité et faciliter la réutilisation des dépendances; 4. Améliorer la réutilisabilité et les classes peuvent être utilisées dans différents environnements. En passant les dépendances en externe aux objets, DI rend le code plus facile à maintenir et à développer.

SendingEmailsWithPhpissstraightForwardusingThemail () functionorMoreAdvancedLibrarySellPhpmailer.1) useMail () forbasiceMails, settingRecipients, sujets, messages, etheaders.2)
