Comme nous le savons tous, il existe d'innombrables frameworks PHP. Ces dernières années, un framework connu pour son élégance a progressivement été connu et a commencé à être utilisé par les PHPers nationaux. Cependant, un défaut évident de Larave est que son contenu de documentation est faible. pitoyable. Cet article vous présente principalement les informations pertinentes sur la façon d'analyser l'injection de dépendances de Laravel via le code source. L'article le présente de manière très détaillée à travers un exemple de code. Il a une certaine valeur d'apprentissage de référence pour l'étude ou le travail de chacun.
Dans la méthode constructeur ou membre du contrôleur de Laravel, l'injection de dépendances peut être utilisée via des contraintes de type, telles que :
public function store(Request $request) { //TODO }
Le paramètre $request utilise ici des contraintes de type, Request est une classe : IlluminateHttpRequest, indiquant que les paramètres doivent être cette classe ou une sous-classe.
Cet article analyse le code source de Laravel pour voir pourquoi Request peut être utilisé directement sans passer d'instance dans la méthode ? C'est juste que le framework instancie et transmet automatiquement les paramètres pour nous.
1. Définition de la route
À partir de la source, une telle route est définie dans le fichier de définition de la route :
Route::resource('/role', 'Admin\RoleController');
Il s'agit d'une route basée sur les ressources. générera automatiquement des entrées de routage pour les ajouts, suppressions, modifications et requêtes.
La méthode store au début de cet article est une méthode de contrôleur. L'action définie par la route est visible dans la figure : AppHttpControllersAdminRoleController@store
Analyse de la méthode d'itinéraireTrouvez le contrôleur et la méthode en fonction de la définition de l'itinéraire, et exécutez la méthode spécifique dans la méthode de répartition. (Fichier : supplier/laravel/framework/src/Illuminate/Routing/ControllerDispatcher.php)public function dispatch(Route $route, $controller, $method) { $parameters = $this->resolveClassMethodDependencies( $route->parametersWithoutNulls(), $controller, $method ); if (method_exists($controller, 'callAction')) { return $controller->callAction($method, $parameters); } return $controller->{$method}(...array_values($parameters)); }
protected function resolveClassMethodDependencies(array $parameters, $instance, $method) { if (! method_exists($instance, $method)) { return $parameters; } return $this->resolveMethodDependencies( $parameters, new ReflectionMethod($instance, $method) ); }
protected function transformDependency(ReflectionParameter $parameter, $parameters) { $class = $parameter->getClass(); // If the parameter has a type-hinted class, we will check to see if it is already in // the list of parameters. If it is we will just skip it as it is probably a model // binding and we do not want to mess with those; otherwise, we resolve it here. if ($class && ! $this->alreadyInParameters($class->name, $parameters)) { return $parameter->isDefaultValueAvailable() ? $parameter->getDefaultValue() : $this->container->make($class->name); } }
class Demo { private $request; public function store(Request $request) { } }
Une brève discussion sur l'injection de dépendances personnalisée du framework Lumen
PHP implémente l'injection automatique de dépendances basée sur mécanisme de réflexion Explication détaillée des compétences method_php
Comment utiliser js pour implémenter l'injection de dépendances
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!