この記事では、ソースコードを通じて Laravel の Dependency Injection を解析する方法に関する関連情報を主に紹介します。この記事は、興味がある方の学習や学習に役立つ情報です。 Laravel フレームワークの友達は、エディターをフォローして一緒に学びましょう。
はじめに
ご存知のとおり、近年、その優雅さで知られるフレームワークが無数に存在し、国内の PHPer の間で使用され始めています。しかし、Larave には明らかな欠点があります。 : it ドキュメントの内容は悲惨です。 この記事では、Laravel の依存関係注入について詳しく説明し、参考と学習のために共有します。以下では多くを説明しません。詳細な紹介を見てみましょう。 Laravel コントローラーのコンストラクター メソッド または メンバー メソッド では、次のような 型制約 を通じて依存関係注入を使用できます。
public function store(Request $request) { //TODO }ここでの $request パラメーターは型制約を使用し、Request はクラス :IlluminateHttpRequest です。 、パラメータがこのクラスまたはサブクラスである必要があることを示します。 この記事では、Laravel のソースコードを分析して、メソッドでインスタンスを渡さずに Request を直接使用できる理由を確認します。フレームワークが自動的にインスタンスを作成し、パラメータを渡してくれるだけです。 ソースから見ると、このようなルートはルート定義ファイルで定義されています:
Route::resource('/role', 'Admin\RoleController');これはリソースベースのルートであり、LaravelはCRUDルートエントリを自動的に生成します。 この記事の冒頭のストアメソッドはコントローラーメソッドです。ルートに定義されているアクションは次の図で確認できます: AppHttpControllersAdminRoleController@store
ルートメソッド分析
に従ってコントローラーとメソッドを見つけます。ルート定義に追加し、特定のメソッドを実行するメソッドはdispatchメソッドに実装されます。 (ファイル: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)); }最初のresolveClassMethodDependencyメソッドは、「名前が示すように」クラスのメソッドパラメータに従って依存オブジェクトを取得することです。次に、クラスメソッドを呼び出し、オブジェクトのパラメータインジェクションを配置します。 複数の依存オブジェクトがある場合、それらは foreach によって順番に解析され、パラメーターとして挿入されます。 依存オブジェクトの例のコードを取得します:
protected function resolveClassMethodDependencies(array $parameters, $instance, $method) { if (! method_exists($instance, $method)) { return $parameters; } return $this->resolveMethodDependencies( $parameters, new ReflectionMethod($instance, $method) ); }ここでの重要な点は、クラスのメソッド パラメータ リストを取得し、パラメータの型制約を知ることができる RelectionMethod メソッドの使用に注意してください。名前などここでの$instanceパラメータはRoleControllerコントローラクラス、$methodパラメータはメソッド名storeです。
2.依存オブジェクトの取得例
から依存オブジェクトの制約タイプを取得します。メソッドのパラメータのみ、この依存オブジェクトをインスタンス化できます。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); } }クラス名に基づいてコンテナからオブジェクトを取得します。オブジェクトインスタンスをバインドするプロセスは、最初にサービスプロバイダーで定義されます。 次に、インスタンス化されたオブジェクトをstoreメソッドに渡すと、依存オブジェクトを使用できるようになります。
3. PHPリフレクションについて
ReflectionMethodの使用例を示します。class Demo { private $request; public function store(Request $request) { } }図に示すように、新しい ReflectionMethod(Demo::class, 'store') の内容を出力します。 このメソッドのパラメーター リストとパラメーターの制約タイプを取得できます。 typeHint、IlluminateHttpRequest.クラスによると、最初にサービスプロバイダーを通じてインスタンスをバインドすることで、名前をコンテナーから取得できます。 関連する推奨事項:
Laravelフレームワーク+Blobで実装されたマルチ画像アップロード機能の例
DockerベースのLaravelアプリケーションをゼロから構築する
以上がソースコードによるLaravelの依存関係注入の解析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。