Heim PHP-Framework Laravel Laravel implementiert eine API-Architektur basierend auf Modulen

Laravel implementiert eine API-Architektur basierend auf Modulen

May 23, 2020 am 10:03 AM
laravel

Laravel implementiert eine API-Architektur basierend auf Modulen

Ich mag es wirklich, Software zu schreiben und auf modularem Design zu programmieren, aber ich mag es nicht, mich auf Softwarepakete und Bibliotheken von Drittanbietern zu verlassen, um einige triviale Dinge zu erledigen, denn das ist nicht der Fall. t Lassen Sie Ihr Programmierniveau erheblich verbessern. Ich schreibe also seit zwei Jahren modulbasierte Software in Laravel und bin mit den Ergebnissen sehr zufrieden.

Der entscheidende Faktor, der mich zu modular aufgebauter Software und Programmiermethoden treibt, ist, dass ich mein Programmierniveau weiter verbessern möchte. Stellen Sie sich vor, Sie bauen eine Projektstruktur auf und stellen 6 Monate später fest, dass das Projekt viele Fehler aufweist. Die Projektarchitektur lässt sich normalerweise nicht einfach ändern, ohne dass sich dies auf den 6 Monate alten Code auswirkt. Bei der Analyse dieses Projekts sind mir zwei Hauptpunkte aufgefallen: Entweder hat man im gesamten Projekt einen Standard und hält sich daran, oder man modularisiert und verbessert Modul für Modul.

Manche Menschen neigen dazu, sich um jeden Preis weiterzuentwickeln und an einem Standard festzuhalten, auch wenn das bedeuten kann, dass sie sich an einen Standard halten, den sie nicht mehr mögen. Persönlich bevorzuge ich eine kontinuierliche Verbesserung, und es spielt keine Rolle, ob sich das 20. Modul völlig vom ersten Modul unterscheidet. Wenn ich eines Tages zu Modul 1 zurückkehren muss, um einen Fehler zu beheben oder umzugestalten, kann ich es auf den neuesten Standard verbessern, der vom 20. Modul verwendet wird.

Angenommen, Sie entwickeln wie ich gerne Laravel-Anwendungen basierend auf Modularität und vermeiden so weit wie möglich das Hinzufügen unnötiger Abhängigkeiten von Drittanbietern zum Projekt – dieser Artikel ist ein Teil meiner Erfahrung.

1- Routing-Dienstleister

Das Laravel-Routing-System kann als Eingang zur gesamten Anwendung bezeichnet werden. Das erste, was geändert werden muss, ist die Standarddatei RouteServiceProvider.php, die die vorhandenen Routen modularisieren soll.

<?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;));
    }
}
Nach dem Login kopieren

Wie oben können wir einfach das gesamte Boilerplate dieser Datei entfernen und einfach eine modulare Routing-Datei einrichten.

2- Moduldateien

Laravel wird mit einigen Dateien im Routenordner geliefert. Da wir diese Routen nicht mehr im RouteServiceProvider abbilden, können wir sie direkt löschen. Als nächstes erstellen wir eine module.php-Routingdatei.

<?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;));
Nach dem Login kopieren

3- Büchermodul

Erstellen Sie im App-Ordner die Datei Modules/Books/routes.php. In dieser Datei können wir Routing-Regeln für das Büchermodul der Anwendung definieren.

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

Sie können Controller-basiertes Routing verwenden, das die Standard-Routing-Methode in Laravel ist, aber ich persönlich bevorzuge die Methode „Auf Wiedersehen Controller, hallo Anfrage-Handler“ (lassen Sie Controller auf und verwenden Sie Anfrage-Handler). Das Folgende ist die Implementierung von 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());
    }
}
Nach dem Login kopieren

Im obigen Code ist BookResource die Ressourcenkonvertierungsebene von Laravel. Gemäß der offiziellen Empfehlung für Namespaces können wir sie im Ordner app/Modules/Books/Resources erstellen.

<?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,
        ];
    }
}
Nach dem Login kopieren

4- Autorenmodul

Wir können das Autorenmodul auch über die Routes-Datei starten.

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

Hinweis: Der Namespace app/Modules/Authors stellt die Dateien dar, die wir schreiben, und ist für Anforderungshandler sehr einfach.

<?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());
    }
}
Nach dem Login kopieren

Zuletzt konvertieren wir die von uns geschriebene Ressourcenklasse in ein responsives JSON-Format.

<?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);
            })
        ];
    }
}
Nach dem Login kopieren

Beachten Sie, wie die Ressource in ein anderes Modul übergeht, um die BookResource wiederzuverwenden. Dies ist normalerweise keine gute Wahl, da Module völlig eigenständig sein sollten und nur Standardklassen wie Eloquent Models oder generische Komponenten wiederverwenden können, die so konzipiert sind, dass sie in allen Modulen gleich sind. Die Lösung für dieses Problem besteht normalerweise darin, die BookResource in das Authors-Modul zu kopieren, sodass Änderungen vorgenommen werden können, ohne ein anderes Modul zu verwenden, und umgekehrt. Ich habe beschlossen, diese modulübergreifende Verwendung beizubehalten. Dieses Beispiel zeigt eine gute Faustregel, um Module voneinander zu isolieren. Wenn Sie jedoch der Meinung sind, dass das obige Beispiel einfach ist und wahrscheinlich keine Probleme verursachen wird. Stellen Sie immer sicher, dass Sie Tests schreiben, die die von Ihnen geschriebene Funktionalität abdecken, um zu verhindern, dass andere Ihre Anwendung unwissentlich ändern.

5- Fazit

Obwohl dies ein sehr einfaches Beispiel ist, hoffe ich, dass es den Menschen ermöglicht, die strukturellen Standards des Laravel-Frameworks einfach entsprechend ihren eigenen Bedürfnissen zu bedienen. Sie können den Speicherort von Dateien ganz einfach ändern, um modulare Anwendungen zu erstellen. Die meisten meiner Projekte enthalten das Modul „App/Components“, das für wiederverwendbare generische Basisklassen für jedes Modul „App/Eloquent“ verwendet werden kann. Der Ordner „Module“ kann zum Speichern von Eloquent-Modellen und relationalen Datenbankmodellen verwendet werden, in denen wir beliebige Funktionalitäten erstellen können zum Thema Modularität. Dies ist die Ordnerverzeichnisstruktur einer Anwendung, an der ich vor kurzem mit der Arbeit begonnen habe:

Laravel implementiert eine API-Architektur basierend auf Modulen

Ich hoffe, dass jeder dieses Konzept daraus lernen kann, jedes Modul hat seine eigenen Bedürfnisse und kann seine eigenen Ordner/Entitäten/Klassen/Methoden/Eigenschaften haben. Es besteht keine Notwendigkeit, alle Module genau gleich zu standardisieren, da einige Module viel einfacher sind als andere und keinen umfangreichen strukturellen Entwurf erfordern. Dieses Beispiel zeigt, wie das AccountChurn-Modul die API über einen HTTP-Ordner bereitstellt und gleichzeitig Artisan-Befehle über die Konsole bereitstellt. AccountOverview hingegen stellt nur eine HTTP-API bereit und verlässt sich auf Warehouses, Wertobjekte (Bags) und Serviceklassen (Paginatoren), um einen größeren Datenwert bereitzustellen.

Empfohlene Tutorials: „PHP-Tutorial“ „Laravel-Tutorial

Das obige ist der detaillierte Inhalt vonLaravel implementiert eine API-Architektur basierend auf Modulen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie bekomme ich den Rückgabecode, wenn das Senden von E -Mails in Laravel fehlschlägt? Wie bekomme ich den Rückgabecode, wenn das Senden von E -Mails in Laravel fehlschlägt? Apr 01, 2025 pm 02:45 PM

Methode zum Abholen des Rücksendecode, wenn das Senden von Laravel -E -Mails fehlschlägt. Wenn Sie Laravel zur Entwicklung von Anwendungen verwenden, stellen Sie häufig Situationen auf, in denen Sie Überprüfungscodes senden müssen. Und in Wirklichkeit ...

Laravel -Zeitplanaufgabe wird nicht ausgeführt: Was soll ich tun, wenn die Aufgabe nicht nach Zeitplan ausgeführt wird: Befehl ausführen? Laravel -Zeitplanaufgabe wird nicht ausgeführt: Was soll ich tun, wenn die Aufgabe nicht nach Zeitplan ausgeführt wird: Befehl ausführen? Mar 31, 2025 pm 11:24 PM

Laravel -Zeitplan -Aufgabe Ausführen nicht reagierende Fehlerbehebung Bei Verwendung der Zeitplanung von Laravel -Zeitplänen werden viele Entwickler auf dieses Problem stoßen: Zeitplan: Run ...

Wie kann man in Laravel mit der Situation umgehen, in der Überprüfungscodes nicht per E -Mail gesendet werden? Wie kann man in Laravel mit der Situation umgehen, in der Überprüfungscodes nicht per E -Mail gesendet werden? Mar 31, 2025 pm 11:48 PM

Die Methode zum Umgang mit Laravels E -Mail -Versagen zum Senden von Verifizierungscode besteht darin, Laravel zu verwenden ...

So implementieren Sie die benutzerdefinierte Tabellenfunktion des Klickens, um Daten im DCAT -Administrator hinzuzufügen? So implementieren Sie die benutzerdefinierte Tabellenfunktion des Klickens, um Daten im DCAT -Administrator hinzuzufügen? Apr 01, 2025 am 07:09 AM

So implementieren Sie die Tabellenfunktion von benutzerdefiniertem Klicken, um Daten in dcatadmin (laravel-admin) hinzuzufügen, wenn Sie DCAT verwenden ...

Laravel – Dump-Server Laravel – Dump-Server Aug 27, 2024 am 10:51 AM

Laravel – Dump-Server – Der Laravel-Dump-Server wird mit der Version von Laravel 5.7 geliefert. Die Vorgängerversionen enthalten keinen Dump-Server. Der Dump-Server wird eine Entwicklungsabhängigkeit in der Laravel-/Laravel-Composer-Datei sein.

Laravel Redis -Verbindungsfreigabe: Warum wirkt sich die Auswahlmethode auf andere Verbindungen aus? Laravel Redis -Verbindungsfreigabe: Warum wirkt sich die Auswahlmethode auf andere Verbindungen aus? Apr 01, 2025 am 07:45 AM

Die Auswirkungen des Austauschs von Redis -Verbindungen im Laravel -Framework und der Auswahl von Methoden bei Verwendung von Laravel -Framework und Redis können Entwickler auf ein Problem stoßen: Durch Konfiguration ...

Laravel Multi-Tenant-Erweiterungsstanz/Mietverhältnis: Wie passen Sie die Host-Adresse einer Mieterdatenbankverbindung an? Laravel Multi-Tenant-Erweiterungsstanz/Mietverhältnis: Wie passen Sie die Host-Adresse einer Mieterdatenbankverbindung an? Apr 01, 2025 am 09:09 AM

Benutzerdefinierte Mieterdatenbankverbindung in Laravel Multi-Tenant-Erweiterungspaket Stanz/Mietverhältnis beim Erstellen von Multi-Mandanten-Anwendungen mit Laravel Multi-Tenant-Erweiterungspaket Stanz/Mietverhältnis, ...

Laravel – Aktions-URL Laravel – Aktions-URL Aug 27, 2024 am 10:51 AM

Laravel – Aktions-URL – Laravel 5.7 führt eine neue Funktion namens „Aufrufbare Aktions-URL“ ein. Diese Funktion ähnelt der in Laravel 5.6, die String-in-Action-Methoden akzeptiert. Der Hauptzweck der neuen Syntax, die Laravel 5.7 eingeführt hat, besteht darin, direktl

See all articles