Heim >Backend-Entwicklung >PHP-Tutorial >Erstellen einer Micro -Markdown -API -App mit Lumen

Erstellen einer Micro -Markdown -API -App mit Lumen

William Shakespeare
William ShakespeareOriginal
2025-02-17 12:37:08439Durchsuche

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.

Building a Micro Markdown API App with Lumen

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

aus. Diese können mit handwerklichen Befehlen hinzugefügt werden:
  • php artisan make foundation resources: Erstellt database und
  • Ordner.
  • 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
<code class="language-php">// app/Http/routes.php

$app->get('/parse', 'App\Http\Controllers\MarkdownController@parse');</code>
<code class="language-php">// 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];
    }
}</code>

/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.

) können aktiviert werden (siehe unten).

Aktivieren von Fassaden, eloquent und Middleware

bootstrap/app.php lumen umfasst Fassaden, eloquentes ORM und Middleware, aber sie sind zunächst in

deaktiviert. Überzeugen Sie diese Zeilen, um sie zu ermöglichen:
<code class="language-php">// app/Http/routes.php

$app->get('/parse', 'App\Http\Controllers\MarkdownController@parse');</code>

Registrieren Sie zusätzliche Dienstanbieter mit $app->register('AppServiceProvider');.

unter Verwendung der API

Testen Sie die API mit einem Werkzeug wie Guzzle:

<code class="language-php">// 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];
    }
}</code>

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.

Building a Micro Markdown API App with Lumen

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!

Stellungnahme:
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