


Detailed explanation of source code analysis and Laravel dependency injection steps
This time I will bring you source code analysis LaravelDependency injectiondetailed steps, source code analysis Laravel dependency injectionWhat are the precautions, the following is a practical case, let's take a look.
Preface
As we all know, there are countless PHP frameworks. In recent years, a framework known for its elegance has gradually been known by domestic PHPers. , and started using it, but one obvious shortcoming of larave is that its documentation content is pitiful.
This article will give you a detailed introduction to Laravel dependency injection and share it for your reference and study. I won’t say much below, let’s take a look at the detailed introduction.
In Laravel's controller's constructor method or member method, you can use dependency injection through type constraints , such as:
public function store(Request $request) { //TODO }
Here, the $request parameter uses type constraints. Request is a class:\Illuminate\Http\Request, which means that the parameter must be this class or a subclass.
This article analyzes the source code of Laravel to see why Request can be used directly without passing in an instance in the method? It’s just that the framework automatically instantiates and passes parameters for us.
1. Route definition
Looking from the source, such a route is defined in the route definition file:
Route::resource('/role', 'Admin\RoleController');
This is a resource-based route. Laravel will automatically generate routing entries for additions, deletions, modifications and queries.
The store method at the beginning of this article is a controller method. The Action defined by the route visible in the figure is also: App\Http\Controllers\Admin\RoleController@store
Routing method analysis
Find the controller and method according to the routing definition, and execute the specific method in the dispatch method.
(File: vendor/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)); }
First resolveClassMethodDependencies method, "as the name suggests" is to obtain dependent objects based on the method parameters of the class, and then Then call the class method and inject the object parameters.
If there are multiple dependent objects, they will be parsed out by foreach in turn and injected as parameters.
Get the code for the dependent object example:
protected function resolveClassMethodDependencies(array $parameters, $instance, $method) { if (! method_exists($instance, $method)) { return $parameters; } return $this->resolveMethodDependencies( $parameters, new ReflectionMethod($instance, $method) ); }
The key point here is the use of PHP reflection. Pay attention to the RelectionMethod method. It obtains the method parameter list of the class and can know the type constraints of the parameters. name etc.
The $instance parameter here is the RoleController controller class, and the $method parameter is the method name store.
2. Example of obtaining dependent objects
After obtaining the constraint type of the dependent object from the method parameters, you can instantiate the dependent object.
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); } }
Get the object from the container based on the class name. The process of binding the object instance is first defined in the service provider.
Then pass the instantiated object into the store method, and you can use the dependent object.
3. About PHP reflection
Give an example of using ReflectionMethod.
class Demo { private $request; public function store(Request $request) { } }
Print out the content of new ReflectionMethod(Demo::class, 'store') as shown in the figure:
php data structure and sequential linked list, detailed explanation of the use of linked linear list
php implements statistical binary Detailed explanation of the steps of the number of 1 algorithm
The above is the detailed content of Detailed explanation of source code analysis and Laravel dependency injection steps. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Method for obtaining the return code when Laravel email sending fails. When using Laravel to develop applications, you often encounter situations where you need to send verification codes. And in reality...

Laravel schedule task run unresponsive troubleshooting When using Laravel's schedule task scheduling, many developers will encounter this problem: schedule:run...

The method of handling Laravel's email failure to send verification code is to use Laravel...

How to implement the table function of custom click to add data in dcatadmin (laravel-admin) When using dcat...

Laravel - Dump Server - Laravel dump server comes with the version of Laravel 5.7. The previous versions do not include any dump server. Dump server will be a development dependency in laravel/laravel composer file.

The impact of sharing of Redis connections in Laravel framework and select methods When using Laravel framework and Redis, developers may encounter a problem: through configuration...

Custom tenant database connection in Laravel multi-tenant extension package stancl/tenancy When building multi-tenant applications using Laravel multi-tenant extension package stancl/tenancy,...

Laravel - Action URL - Laravel 5.7 introduces a new feature called “callable action URL”. This feature is similar to the one in Laravel 5.6 which accepts string in action method. The main purpose of the new syntax introduced Laravel 5.7 is to directl
