Heim >Backend-Entwicklung >PHP-Tutorial >Disco mit Entwurfsmustern: Ein neuer Blick auf die Abhängigkeitsinjektion
Kernpunkte
@Bean
und @Configuration
und vereinfacht damit die Einrichtung des Dienstes. Der Kern der Abhängigkeitsinjektion liegt in der Wiederverwendbarkeit des Codes. Es ist ein Entwurfsmuster, das die Wiederverwendbarkeit von erweitertem Code durch die Trennung von Objekterstellung/-konfiguration von der Nutzung verbessern soll.
Betrachten Sie den folgenden Code:
<code class="language-php">class Test { protected $dbh; public function __construct(\PDO $dbh) { $this->dbh = $dbh; } } $dbh = new PDO('mysql:host=localhost;dbname=test', 'username', 'password'); $test = new Test($dbh);</code>
Wie Sie sehen können, erstellen wir es außerhalb der Klasse, anstatt ein PDO -Objekt innerhalb der Klasse zu erstellen und über einen Konstruktor als Abhängigkeit weiterzugeben. Auf diese Weise können wir den Treiber unserer Wahl verwenden, ohne den in der Klasse definierten Treiber verwenden zu müssen.
Alejandro Gervasio und Fabien Potencier liefern wundervolle Erklärungen für das Konzept von DI.
Dieses Muster hat jedoch einen Nachteil: Wenn die Anzahl der Abhängigkeiten zunimmt, ist es erforderlich, viele Objekte zu erstellen/zu konfigurieren, bevor sie an die abhängigen Objekte weitergegeben werden. Es kann am Ende viel Boilerplate -Code sowie eine lange Warteschlange des Parameters im Konstruktor erzeugen. Zu diesem Zeitpunkt müssen Sie Abhängigkeitsinjektionsbehälter!
Abhängigkeitsinjektionsbehälter (kurz DI -Container) ist ein Objekt, das weiß, wie man einen Dienst erstellt und seine Abhängigkeiten abwickelt.
In diesem Artikel werden wir einen aufstrebenden DI -Container, Disco, verwenden, um dieses Konzept weiter zu demonstrieren.
Weitere Informationen zu Abhängigkeitsinjektionsbehältern finden Sie in unseren anderen Artikeln zu diesem Thema.
Da Frameworks ein gutes Beispiel für die Bereitstellung von DI-Containern sind, werden wir am Ende des Artikels mit Disco und einigen Symfony-Komponenten ein grundlegendes HTTP-basierter Framework erstellen.
Installation
Um Disco zu installieren, verwenden wir den Komponisten wie gewohnt:
<code class="language-bash">composer require bitexpert/disco</code>
Um den Code zu testen, verwenden wir den integrierten Webserver von PHP:
<code class="language-php">class Test { protected $dbh; public function __construct(\PDO $dbh) { $this->dbh = $dbh; } } $dbh = new PDO('mysql:host=localhost;dbname=test', 'username', 'password'); $test = new Test($dbh);</code>
Infolge Datei befindet sich.
-t
Anfänger index.php
Disco ist ein DI -Behälter, der mit Behältern interoperabel ist. Disco ist kontrovers ein DI -Behälter, der auf Annotation basiert.
Beachten Sie, dass das-Paket eine Reihe von Schnittstellen enthält, um die Eigenschaften von Containerobjekten zu standardisieren. Um zu verstehen, wie es funktioniert, finden Sie in unserem Tutorial zum Aufbau unseres eigenen Injektionsbehälters von SitePoint -Abhängigkeiten, der auch auf
basiert.
container-interop
Um dem Container einen Dienst hinzuzufügen, müssen wir eine Konfigurationsklasse erstellen. Dieser Typ sollte container-interop
Annotationszeichen verwenden:
Jeder Containerdienst sollte in der Konfigurationsklasse als öffentliche oder geschützte Methode definiert werden. Disco nennt jeden Dienst eine Bohne, die aus der Java -Kultur stammt. @Configuration
<code class="language-bash">composer require bitexpert/disco</code>gekennzeichnet sein (was bedeutet, dass dies ein Dienst ist) und der Typ des Rückgabeobjekts ist mit
Annotation markiert.
Dies ist ein einfaches Beispiel für Disco -Konfigurationsklassen, das eine "Bean" enthält: @Bean
@return
Annotation akzeptiert einige Konfigurationsparameter, um die Art des Dienstes anzugeben. Diese Parameter geben an, ob es sich bei dem Dienst um ein Singleton-Objekt, eine Verzögerung des Ladens (falls das Objekt ressourcenintensiv ist) sein sollte oder seinen Zustand während der gesamten Sitzung fortsetzt.
<code class="language-bash">php -S localhost:8000 -t web</code>Standardmäßig werden alle Dienste als Singleton -Dienste definiert.
@Bean
Zum Beispiel erstellt die folgende Bean einen Singleton Lazy Loading -Service:
Disco verwendet Proxymanager, um die Belastung von Diensten zu verzögern. Es wird auch verwendet, um zusätzliches Verhalten (definiert durch Annotationen) in die Methoden der Konfigurationsklasse injizieren.
Nach dem Erstellen der Konfigurationsklasse müssen wir eine Instanz von
<code class="language-php"><?php /** * @Configuration */ class Services { // ... }</code>erstellen und die Konfigurationsklasse an sie übergeben. Dies wird unser Behälter sein.
Schließlich registrieren wir den Container in
: AnnotationBeanFactory
So erhalten Sie Dienste von Container BeanFactoryRegistry
<code class="language-php"><?php /** * @Configuration */ class Configuration { /** * @Bean * @return SampleService */ public function getSampleService() { // 实例化 $service = new SampleService(); // 配置 $service->setParameter('key', 'value'); return $service; } }</code>und
get()
has()
(Der folgende Inhalt ähnelt dem Originaltext. Um Platz zu erhalten, werden einige Details hier weggelassen, aber Schlüsselinformationen und Struktur bleiben beibehalten)
<code class="language-php"><?php // ... /** * @Bean({"singleton"=true, "lazy"=true}) * @return \Acme\SampleService */ public function getSampleService() { return new SampleService(); } // ...</code>
Service -Geltungsbereich
Containerparameter
Praktische Anwendung von Disco
Erstellen Sie einen Antworthörer
Schlussfolgerung
Dieser Artikel nur Pseudooriginalverarbeitung des Originaltextes und subtile Anpassungen und umgeschriebene Inhalte vorgenommen, wodurch sich der Artikel reibungsloser und natürlicher gestaltet, ohne die allgemeine Bedeutung des Originaltextes zu ändern. Das Bildformat und die Position bleiben unverändert.
Das obige ist der detaillierte Inhalt vonDisco mit Entwurfsmustern: Ein neuer Blick auf die Abhängigkeitsinjektion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!