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

Erstellen einer Micro -Markdown -API -App mit Lumen

William Shakespeare
Freigeben: 2025-02-17 12:37:08
Original
432 Leute haben es durchsucht

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
// app/Http/routes.php

$app->get('/parse', 'App\Http\Controllers\MarkdownController@parse');
Nach dem Login kopieren
Nach dem Login kopieren
// 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];
    }
}
Nach dem Login kopieren
Nach dem Login kopieren

/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: <🎜>
// app/Http/routes.php

$app->get('/parse', 'App\Http\Controllers\MarkdownController@parse');
Nach dem Login kopieren
Nach dem Login kopieren

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

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!

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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage