


Was ist das Implementierungsprinzip der Abhängigkeitsinjektion in Laravel?
In Laravel besteht das Implementierungsprinzip der Abhängigkeitsinjektion darin, die Klassenmethodenreflexion zu verwenden, um den Parametertyp abzurufen, dann den Container zum Erstellen der Instanz zu verwenden und sie dann mit der Rückruffunktion aufzurufen. Der injizierte Objektkonstruktor kann keine Parameter haben Andernfalls wird ein Fehler gemeldet und die Abhängigkeitsinjektion muss von der Router-Klasse aufgerufen werden, andernfalls kann die Injektion nicht direkt mit der neuen Methode erreicht werden.
Die Betriebsumgebung dieses Artikels: Windows 10-System, Laravel Version 6, Dell G3-Computer.
Was ist das Implementierungsprinzip der Abhängigkeitsinjektion von Laravel?
Der Laravel-Container umfasst die Umkehrung der Kontrolle und die Abhängigkeitsinjektion. Um es zu verwenden, binden Sie einfach zuerst das Objekt und Sie können es bei Bedarf direkt abrufen.
Eine spezifische Analyse finden Sie unter: http://laravelacademy.org/post/769.html
Normalerweise lauten unsere Anrufe wie folgt.
$config = $container->make('config'); $connection = new Connection($this->config);
Der Vorteil besteht darin, dass Sie eine Instanz nicht direkt neu erstellen müssen. Es gibt keine Änderung am von der Methode übergebenen Wert. Sie können diese Instanz auch an mehreren Stellen teilen.
Aber was hat das mit der Abhängigkeitsinjektion zu tun? Für eine echte Abhängigkeitsinjektion müssen keine Parameterwerte an die Methode übergeben werden. Sie müssen nur den Parametertyp der Methode angeben, und der Code findet die Beziehung automatisch und fügt sie automatisch ein die Abhängigkeit.
Diese Funktion kann sich wie folgt im Controller, Job usw. von Laravel widerspiegeln:
class TestController extends Controller { public function anyConsole(Request $request, Auth $input) { //todo } }
Sehen wir uns an, wie es die automatische Abhängigkeitsinjektion implementiert:
Der Kernel wird von index.PHP aufgerufen und über mehrere Ebenen aufgerufen Kernel-Pipelines und dann „To Router“ rufen über eine mehrschichtige Middleware-Pipeline auf. Schließlich befindet es sich in Zeile 124 von
Illuminate/Routing/Route.php.
public function run(Request $request) { $this->container = $this->container ?: new Container; try { if (! is_string($this->action['uses'])) { return $this->runCallable($request); } if ($this->customDispatcherIsBound()) { return $this->runWithCustomDispatcher($request); } return $this->runController($request); } catch (HttpResponseException $e) { return $e->getResponse(); } }
Bestimmen Sie, ob $this->action[‘uses’] (Formatzeile wie: AppHttpControllerDatacenterRealTimeController@anyConsole) eine Zeichenfolge ist. $this->customDispatcherIsBound bestimmt, ob eine benutzerdefinierte Route gebunden ist. Springen Sie dann zu $this->runController($request).
protected function runController(Request $request) { list($class, $method) = explode('@', $this->action['uses']); $parameters = $this->resolveClassMethodDependencies( $this->parametersWithoutNulls(), $class, $method ); if (! method_exists($instance = $this->container->make($class), $method)) { throw new NotFoundHttpException; } return call_user_func_array([$instance, $method], $parameters); }
$this->resolveClassMethodDependencies Schon beim Blick auf den Namen erkennt man, dass es sich bei dieser Methode um die Methode handelt, nach der wir suchen. $this->parametersWithoutNulls() dient zum Herausfiltern von Nullzeichen. $class und $method lauten wie folgt: AppHttpControllerDatacenterRealTimeController bzw. anyConsole.
protected function resolveClassMethodDependencies(array $parameters, $instance, $method) { if (! method_exists($instance, $method)) { return $parameters; } return $this->resolveMethodDependencies( $parameters, new ReflectionMethod($instance, $method) ); }
new ReflectionMethod($instance, $method) ist das Reflexionsobjekt, das die Klassenmethode erhält, siehe Dokument: http://www.php.net/manual/zh/class.reflectionmethod.php
Springe zu Illuminate unten /Routing/RouteDependencyResolverTrait.php Zeile 54.
public function resolveMethodDependencies(array $parameters, ReflectionFunctionAbstract $reflector) { $originalParameters = $parameters; foreach ($reflector->getParameters() as $key => $parameter) { $instance = $this->transformDependency( $parameter, $parameters, $originalParameters ); if (! is_null($instance)) { $this->spliceIntoParameters($parameters, $key, $instance); } } return $parameters; }
Rufen Sie das Klassenparameter-Array über die Reflection-Klassenmethode ab, durchlaufen Sie es dann und übergeben Sie es an die Methode $this->transformDependency. Wenn die Instanz nicht abgerufen werden kann, rufen Sie $this->spliceIntoParameters auf, um die Parameter zu löschen.
protected function transformDependency(ReflectionParameter $parameter, $parameters, $originalParameters) { $class = $parameter->getClass(); if ($class && ! $this->alreadyInParameters($class->name, $parameters)) { return $this->container->make($class->name); } }
Endlich habe ich den Schatten des Containers gesehen. Ja, das endgültige Objekt wurde durch die Make-Methode des Containers herausgenommen. Zu diesem Zeitpunkt werden die Parameter erstellt und schließlich vom call_user_func_array der runController-Methode zurückgerufen.
Zusammenfassung:
Das Prinzip der Abhängigkeitsinjektion besteht eigentlich darin, die Klassenmethodenreflexion zu verwenden, um den Parametertyp zu erhalten, und dann den Container zum Erstellen der Instanz zu verwenden. Verwenden Sie dann die Callback-Funktion, um es aufzurufen.
Der injizierte Objektkonstruktor darf keine Parameter haben. Andernfalls wird ein Fehler gemeldet. Fehlendes Argument 1
Abhängigkeitsinjektion ist gut, muss aber von der Router-Klasse aufgerufen werden, sonst kann die Injektion nicht direkt mit der neuen Methode erreicht werden. Aus diesem Grund können nur Controller- und Job-Klassen diese Funktion nutzen.
【Verwandte Empfehlungen: Laravel-Video-Tutorial】
Das obige ist der detaillierte Inhalt vonWas ist das Implementierungsprinzip der Abhängigkeitsinjektion in Laravel?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Datenbankoperationen in PHP werden durch ORM vereinfacht, das Objekte in relationalen Datenbanken abbildet. EloquentORM in Laravel ermöglicht Ihnen die Interaktion mit der Datenbank mithilfe einer objektorientierten Syntax. Sie können ORM verwenden, indem Sie Modellklassen definieren, Eloquent-Methoden verwenden oder in der Praxis ein Blog-System erstellen.

Die neuesten Versionen von Laravel 9 und CodeIgniter 4 bieten aktualisierte Funktionen und Verbesserungen. Laravel9 übernimmt die MVC-Architektur und bietet Funktionen wie Datenbankmigration, Authentifizierung und Template-Engine. CodeIgniter4 nutzt die HMVC-Architektur, um Routing, ORM und Caching bereitzustellen. In Bezug auf die Leistung sorgen das auf Dienstanbietern basierende Designmuster von Laravel9 und das leichte Framework von CodeIgniter4 für eine hervorragende Leistung. In praktischen Anwendungen eignet sich Laravel9 für komplexe Projekte, die Flexibilität und leistungsstarke Funktionen erfordern, während CodeIgniter4 für schnelle Entwicklung und kleine Anwendungen geeignet ist.

Vergleichen Sie die Datenverarbeitungsfunktionen von Laravel und CodeIgniter: ORM: Laravel verwendet EloquentORM, das eine relationale Klassen-Objekt-Zuordnung bereitstellt, während CodeIgniter ActiveRecord verwendet, um das Datenbankmodell als Unterklasse von PHP-Klassen darzustellen. Abfrage-Builder: Laravel verfügt über eine flexible verkettete Abfrage-API, während der Abfrage-Builder von CodeIgniter einfacher und Array-basiert ist. Datenvalidierung: Laravel bietet eine Validator-Klasse, die benutzerdefinierte Validierungsregeln unterstützt, während CodeIgniter über weniger integrierte Validierungsfunktionen verfügt und eine manuelle Codierung benutzerdefinierter Regeln erfordert. Praxisfall: Beispiel einer Benutzerregistrierung zeigt Lar

Laravel – Artisan Commands – Laravel 5.7 bietet eine neue Möglichkeit, neue Befehle zu behandeln und zu testen. Es enthält eine neue Funktion zum Testen von Handwerkerbefehlen und die Demonstration wird unten erwähnt?

Für Anfänger bietet CodeIgniter eine sanftere Lernkurve und weniger Funktionen, deckt aber die Grundbedürfnisse ab. Laravel bietet einen größeren Funktionsumfang, weist jedoch eine etwas steilere Lernkurve auf. In Bezug auf die Leistung schneiden sowohl Laravel als auch CodeIgniter gut ab. Laravel verfügt über eine umfangreichere Dokumentation und aktive Community-Unterstützung, während CodeIgniter einfacher und leichtgewichtiger ist und über starke Sicherheitsfunktionen verfügt. Im praktischen Fall der Erstellung einer Blogging-Anwendung vereinfacht EloquentORM von Laravel die Datenmanipulation, während CodeIgniter mehr manuelle Konfiguration erfordert.

Bei der Auswahl eines Frameworks für große Projekte haben Laravel und CodeIgniter jeweils ihre eigenen Vorteile. Laravel ist für Anwendungen auf Unternehmensebene konzipiert und bietet modularen Aufbau, Abhängigkeitsinjektion und einen leistungsstarken Funktionsumfang. CodeIgniter ist ein leichtes Framework, das sich eher für kleine bis mittelgroße Projekte eignet und Wert auf Geschwindigkeit und Benutzerfreundlichkeit legt. Für große Projekte mit komplexen Anforderungen und einer großen Anzahl von Benutzern sind die Leistung und Skalierbarkeit von Laravel besser geeignet. Für einfache Projekte oder Situationen mit begrenzten Ressourcen sind die leichten und schnellen Entwicklungsfunktionen von CodeIgniter idealer.

Die Microservice-Architektur nutzt PHP-Frameworks (wie Symfony und Laravel) zur Implementierung von Microservices und folgt RESTful-Prinzipien und Standarddatenformaten zum Entwerfen von APIs. Microservices kommunizieren über Nachrichtenwarteschlangen, HTTP-Anfragen oder gRPC und nutzen Tools wie Prometheus und ELKStack zur Überwachung und Fehlerbehebung.

Für kleine Projekte eignet sich Laravel, für größere Projekte, die starke Funktionalität und Sicherheit erfordern. CodeIgniter eignet sich für sehr kleine Projekte, die geringes Gewicht und Benutzerfreundlichkeit erfordern.
