Lumen: Eine leichte Laravel -Alternative für Microservices und APIs
Dieses Tutorial zeigt, dass eine Markdown-Parser-API unter Verwendung von Lumen erstellt wird, ein Mikro-Framework, das auf Laravel-Illuminate-Komponenten basiert. Das leichte Natur von Lumen ist ideal für kleine Anwendungen und Dienste und sorgt für schnelle Startzeiten, indem sie selektiv Komponenten laden. Wir nutzen das league/commonmark
-Paket für die Markdown -Parsen.
Warum Lumen wählen?
lumen bietet einen optimierten Ansatz für Entwickler, die bereits mit Laravels Syntax und Eleganz vertraut sind. Im Gegensatz zu Laravels Full-Stack-Architektur vermeidet Lumen unnötige Komponenten (eloquent, klinge usw.), was zu einem kleineren, schnelleren Anwendungs-Fußabdruck führt, perfekt für fokussierte Aufgaben.
Projekt -Setup: Eine Markdown -Parser -API
Unsere Anwendung akzeptiert Markdown -Text als Eingabe und gibt die analysierte HTML als JSON zurück. Dies zeigt Lumens Fähigkeiten in einem praktischen Kontext. Der vollständige Code ist auf GitHub verfügbar (Link links gemäß Originaltext).
Installation und Abhängigkeiten
composer global require "laravel/lumen-installer=~1.0"
Verwenden Sie das Lumen -Installationsprogramm (lumen new my-project
) für die schnelle Projekterstellung (composer create-project laravel/lumen my-project --prefer-dist
). Verwenden Sie alternativ Komponist: league/commonmark
. Installieren Sie composer require league/commonmark
mit
Verzeichnisstruktur
config
lumens magere Struktur lässt zunächst Ordner wie database
, resources
und
php artisan make foundation
resources
: Erstellt database
und php artisan make resources
resources
: Erstellt den Ordner php artisan make database
database
: Erstellt den Ordner php artisan make lang
resources/lang
: Erstellt den Ordner php artisan make views
resources/views
: Erstellt den Ordner Implementierung des Markdown -Parsers
// app/Http/routes.php $app->get('/parse', 'App\Http\Controllers\MarkdownController@parse');
// app/Http/Controllers/MarkdownController.php namespace App\Http\Controllers; use Illuminate\Http\Request; use League\CommonMark\CommonMarkConverter; class MarkdownController extends Controller { public function parse(Request $request, CommonMarkConverter $parser) { $text = $request->get('text'); $result = $parser->convertToHtml($text); return ['html' => $result]; } }
/parse
Der Endpunkt league/commonmark
erhält Markdown -Text, analysiert ihn mit CommonMarkConverter
und gibt das HTML -Ergebnis als JSON -Antwort zurück. Die Abhängigkeitsinjektion behandelt die Objekte Request
und Request::get('text')
. Fassaden (z. B.
Aktivieren von Fassaden, eloquent und Middleware
bootstrap/app.php
lumen umfasst Fassaden, eloquentes ORM und Middleware, aber sie sind zunächst in
// app/Http/routes.php $app->get('/parse', 'App\Http\Controllers\MarkdownController@parse');
Registrieren Sie zusätzliche Dienstanbieter mit $app->register('AppServiceProvider');
.
unter Verwendung der API
Testen Sie die API mit einem Werkzeug wie Guzzle:
// app/Http/Controllers/MarkdownController.php namespace App\Http\Controllers; use Illuminate\Http\Request; use League\CommonMark\CommonMarkConverter; class MarkdownController extends Controller { public function parse(Request $request, CommonMarkConverter $parser) { $text = $request->get('text'); $result = $parser->convertToHtml($text); return ['html' => $result]; } }
Schlussfolgerung
lumen bietet eine überzeugende Alternative für kleinere Projekte, wodurch die Stärken von Laravel genutzt werden und gleichzeitig ein leichtes Profil beibehalten werden. Seine Benutzerfreundlichkeit und Erweiterbarkeit machen es zu einem wertvollen Werkzeug für Microservices und APIs. Die vollständige Dokumentation bietet weitere Details.
Das obige ist der detaillierte Inhalt vonErstellen einer Micro -Markdown -API -App mit Lumen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!