検索
ホームページPHPフレームワークLaravelLaravelはモジュールに基づいてAPIアーキテクチャを実装します

Laravelはモジュールに基づいてAPIアーキテクチャを実装します

私はモジュール設計に基づいてソフトウェアやプログラミングを書くのが大好きですが、些細なことを処理するためにサードパーティのソフトウェア パッケージやライブラリに依存するのはあまり好きではありません。あなたのプログラミングレベルを大幅に向上させましょう。そこで、私は過去 2 年間、Laravel でモジュールベースのソフトウェアを書いてきましたが、その結果には非常に満足しています。

モジュール設計に基づくソフトウェアとプログラミング手法に私を駆り立てた決定的な要因は、自分のプログラミング レベルを向上させ続けたいということです。プロジェクト構造を構築し、6 か月後にプロジェクトに多くのバグがあることに気付いたと想像してください。通常、プロジェクトのアーキテクチャは、6 か月にわたる既存のコードに影響を与えずに変更するのは簡単ではありません。このプロジェクトを分析しているときに、2 つの主要な点に気づきました。それは、プロジェクト全体で標準を設けてそれに固執するか、モジュール化してモジュールごとに改善するかのどちらかです。

一部の人々は、たとえ気に入らない標準に従うことになるとしても、どんな犠牲を払ってでも開発し、標準に従う傾向があります。個人的には、継続的な改善を好みます。20 番目のモジュールが最初のモジュールと完全に異なっていても問題ありません。ある日、バグを修正したりリファクタリングするためにモジュール 1 に戻る必要がある場合、モジュール 20 で使用される最新の標準に改善できます。

あなたも、私と同じように、モジュール性に基づいて Laravel アプリケーションを開発し、プロジェクトに不必要なサードパーティの依存関係をできるだけ追加しないようにしているとします。この記事は私の経験の一部です。

1- ルーティング サービス プロバイダー

Laravel ルーティング システムは、アプリケーション全体への入り口であると言えます。最初に変更する必要があるのは、デフォルトの RouteServiceProvider.php ファイルで、既存のルートをモジュール化する必要があります。

<?php
namespace App\Providers;
use Illuminate\Support\Facades\Route;
use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
class RouteServiceProvider extends ServiceProvider
{
    /**
     * 定义应用路由。
     *
     * @return void
     */
    public function map()
    {
        $this->mapModulesRoutes();
    }
    protected function mapModulesRoutes()
    {
        // 如果你在编写传统 Web 应用而非 HTTP API,请使用 `web` 中间件。 
        Route::middleware(&#39;api&#39;)
             ->group(base_path(&#39;routes/modules.php&#39;));
    }
}

上記のように、このファイルのボイラープレート全体を直接削除して、モジュラー ルーティング ファイルをセットアップするだけです。

2- モジュールファイル

Laravel には、routes フォルダーにいくつかのファイルが付属しています。これらのルートは RouteServiceProvider にマッピングされなくなったので、直接削除できます。次に、modules.php ルーティング ファイルを作成します。

<?php
use Illuminate\Support\Facades\Route;
Route::group([], base_path(&#39;app/Modules/Books/routes.php&#39;));
Route::group([], base_path(&#39;app/Modules/Authors/routes.php&#39;));

3- Books module

アプリ フォルダーに Modules/Books/routes.php ファイルを作成します。このファイルでは、アプリケーションの Books モジュールのルーティング ルールを定義できます。

<?php
use App\Modules\Books\ListBooks;
use Illuminate\Support\Facades\Route;
Route::get(&#39;/books&#39;, ListBooks::class);

Laravel のデフォルトの標準ルーティング方法であるコントローラーベースのルーティングを使用することもできますが、個人的には「Good byeコントローラー、hello Request Handlers」(コントローラーを放棄してリクエストハンドラーを使用する) の方法を好みます。以下はListBooksの実装です。

<?php
namespace App\Modules\Books;
use App\Eloquent\Book;
use App\Modules\Books\Resources\BookResource;
class ListBooks
{
    public function __invoke(Book $book)
    {
        return BookResource::collection($book->paginate());
    }
}

上記のコードでは、BookResource は Laravel のリソース変換層です。名前空間の公式推奨に従って、app/Modules/Books/Resources フォルダーに名前空間を作成できます。

<?php
namespace App\Modules\Books\Resources;
use Illuminate\Http\Resources\Json\Resource;
class BookResource extends Resource
{
    public function toArray($request)
    {
        return [
            &#39;id&#39; => $this->resource->id,
            &#39;title&#39; => $this->resource->title,
        ];
    }
}

4- Authors モジュール

Routes ファイルを通じて Authors モジュールを開始することもできます。

<?php
use App\Modules\Authors\ListAuthors;
use Illuminate\Support\Facades\Route;
Route::get(&#39;/authors&#39;, ListAuthors::class);

注: 名前空間 app/Modules/Authors は、作成したファイルを表しており、リクエスト ハンドラーにとっても非常に単純です。

<?php
namespace App\Modules\Authors;
use App\Eloquent\Author;
use App\Modules\Authors\Resources\AuthorResource;
class ListAuthors
{
    public function __invoke(Author $author)
    {
        return AuthorResource::collection($author->paginate());
    }
}

最後に、作成した Resource クラスをレスポンシブな JSON 形式に変換します。

<?php
namespace App\Modules\Authors\Resources;
use App\Modules\Books\Resources\BookResource;
use Illuminate\Http\Resources\Json\Resource;
class AuthorResource extends Resource
{
    public function toArray($request)
    {
        return [
            &#39;id&#39; => $this->resource->id,
            &#39;name&#39; => $this->resource->name,
            &#39;books&#39; => $this->whenLoaded(&#39;books&#39;, function () {
                return BookResource::collection($this->resource->books);
            })
        ];
    }
}

リソースが別のモジュールに移動して BookResource を再利用する方法に注目してください。モジュールは完全に自立している必要があり、Eloquent Models などの標準クラスや、モジュール間で共通するように設計された汎用コンポーネントのみを再利用できるため、これは通常は良い選択ではありません。この問題の解決策は通常、BookResource を Authors モジュールにコピーして、別のモジュールを使用せずに変更を加えられるようにすること、またはその逆を行うことです。このクロスモジュールの使用法を維持することにしました。この例は、モジュールを相互に分離しておくための適切な経験則を示していますが、上記の例は単純で問題が発生する可能性は低いと思われる場合は、他の人が知らないうちにアプリケーションを変更しないように、自分が作成した機能をカバーするテストを必ず作成してください。

5-結論

これは非常に単純な例ですが、これにより、人々が自分のニーズに応じて Laravel フレームワークの構造標準を簡単に操作できるようになることを願っています。 。モジュールベースのアプリケーションを構築するために、ファイルの場所を非常に簡単に変更できます。私のプロジェクトのほとんどには、任意のモジュールの再利用可能な汎用基本クラスに使用できる App/Components モジュールが付属しています。App/Eloquent の Modules フォルダーは、Eloquent モデルとデータベース リレーショナル モデルを保持するために使用でき、そこで任意の機能ベースを構築できます。モジュール性について。これは、私が最近作業を始めたアプリケーションのフォルダー ディレクトリ構造です:

Laravelはモジュールに基づいてAPIアーキテクチャを実装します

各モジュールには独自のニーズがあり、独自のフォルダー/エンティティ/クラス/メソッド/プロパティを持つことができます。一部のモジュールは他のモジュールよりもはるかに単純であり、広範な構造設計を必要としないため、すべてのモジュールをまったく同じに標準化する必要はありません。この例では、AccountChurn モジュールが HTTP フォルダー経由で API を提供しながら、コンソール経由でアーティザン コマンドを提供していることを示しています。一方、AccountOverview は HTTP API のみを提供し、ウェアハウス、値オブジェクト (バッグ)、およびサービス クラス (ページネーター) に依存して、より大きなデータ値を提供します。

推奨チュートリアル: 「PHP チュートリアル 」 「Laravel チュートリアル

以上がLaravelはモジュールに基づいてAPIアーキテクチャを実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事はlearnkuで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
Laravel(PHP)vs。Python:開発環境とエコシステムLaravel(PHP)vs。Python:開発環境とエコシステムApr 12, 2025 am 12:10 AM

開発環境とエコシステムにおけるLaravelとPythonの比較は次のとおりです。1。Laravelの開発環境は簡単で、PHPと作曲家のみが必要です。 Laravelforgeなどの豊富な範囲の拡張パッケージを提供しますが、拡張パッケージのメンテナンスはタイムリーではない場合があります。 2。Pythonの開発環境もシンプルで、PythonとPIPのみが必要です。エコシステムは巨大で複数のフィールドをカバーしていますが、バージョンと依存関係の管理は複雑な場合があります。

LaravelとThe BackEnd:Webアプリケーションロジックの電源LaravelとThe BackEnd:Webアプリケーションロジックの電源Apr 11, 2025 am 11:29 AM

Laravelはバックエンドロジックでどのように役割を果たしますか?ルーティングシステム、Eloquentorm、認証と承認、イベントとリスナー、パフォーマンスの最適化を通じてバックエンド開発を簡素化および強化します。 1.ルーティングシステムにより、URL構造の定義とリクエスト処理ロジックが可能になります。 2.Eloquentormは、データベースの相互作用を簡素化します。 3.認証および承認システムは、ユーザー管理に便利です。 4.イベントとリスナーは、ゆるく結合したコード構造を実装します。 5.パフォーマンスの最適化により、キャッシュとキューイングを通じてアプリケーションの効率が向上します。

Laravelがそんなに人気があるのはなぜですか?Laravelがそんなに人気があるのはなぜですか?Apr 02, 2025 pm 02:16 PM

Laravelの人気には、単純化された開発プロセスが含まれ、快適な開発環境を提供し、豊富な機能が提供されます。 1)Rubyonrailsの設計哲学を吸収し、PHPの柔軟性を組み合わせています。 2)Eloquentorm、Bladeテンプレートエンジンなどのツールを提供して、開発効率を向上させます。 3)そのMVCアーキテクチャと依存関係噴射メカニズムにより、コードがよりモジュール化され、テスト可能になります。 4)キャッシュシステムやベストプラクティスなどの強力なデバッグツールとパフォーマンス最適化方法を提供します。

どちらが良いのか、DjangoとLaravel?どちらが良いのか、DjangoとLaravel?Mar 28, 2025 am 10:41 AM

DjangoとLaravelはどちらもフルスタックのフレームワークです。 DjangoはPython開発者や複雑なビジネスロジックに適していますが、LaravelはPHP開発者とエレガントな構文に適しています。 1.DjangoはPythonに基づいており、迅速な発展と高い並行性に適した「バッテリーコンプリート」哲学に従います。 2. LaravelはPHPに基づいており、開発者エクスペリエンスを強調しており、小規模から中規模のプロジェクトに適しています。

どちらがより良いPHPですか、それともLaravelですか?どちらがより良いPHPですか、それともLaravelですか?Mar 27, 2025 pm 05:31 PM

LaravelはPHPベースのフレームワークであるため、PHPとLaravelは直接匹敵するものではありません。 1.PHPは、シンプルで直接的であるため、小規模プロジェクトや迅速なプロトタイピングに適しています。 2。LARAVELは、豊富な機能とツールを提供するため、大規模なプロジェクトや効率的な開発に適していますが、急な学習曲線があり、純粋なPHPほど良くない場合があります。

Laravelはフロントエンドですか、それともバックエンドですか?Laravelはフロントエンドですか、それともバックエンドですか?Mar 27, 2025 pm 05:31 PM

laravelisabackendframeworkbuiltonphp、designforwebapplicationdevelopment.itfocusonserver-sidelogic、databasemanagement、およびapplicationStructure、およびbueithedendtechnologiesvue.jsorreactforfull-stackdevelymentと統合されていること。

Laravelでカスタムブレードディレクティブを作成および使用するにはどうすればよいですか?Laravelでカスタムブレードディレクティブを作成および使用するにはどうすればよいですか?Mar 17, 2025 pm 02:50 PM

この記事では、Laravelでカスタムブレードディレクティブの作成と使用を行い、テンプレートを強化します。ディレクティブの定義、テンプレートでそれらを使用し、大規模なプロジェクトでそれらを管理することをカバーし、改善されたコードの再利用性やRなどの利点を強調しています

Laravelのコンポーネントを使用して再利用可能なUI要素を作成するにはどうすればよいですか?Laravelのコンポーネントを使用して再利用可能なUI要素を作成するにはどうすればよいですか?Mar 17, 2025 pm 02:47 PM

この記事では、コンポーネントを使用してLaravelで再利用可能なUI要素の作成とカスタマイズについて説明し、組織のベストプラクティスを提供し、パッケージを強化することを提案します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン