Der Aufbau einer API kann entmutigend erscheinen, aber es muss nicht sein. Dieses Tutorial zeigt, wie eine einfache, schreibgeschützte API in einer Stunde mit minimalem Code und leicht verfügbaren Tools erstellt und bereitgestellt wird. Es ist keine umfangreiche Back-End-Erfahrung erforderlich. Ein grundlegendes Verständnis von JavaScript und NPM ist ausreichend.
Diese Anleitung entmystifiziert gemeinsame API -Konzepte wie REST und führt GraphQL und serverlose Architekturen ein. Wir werden leicht verfügbare Tools verwenden und ihren Zweck auf dem Weg erläutern. Am Ende haben Sie eine bereitgestellte API ohne Serververwaltungskopfschmerzen.
Schlüsselkonzepte: GraphQL und serverlos
APIs beinhalten grundlegend das Lesen und Aktualisieren von Daten. REST -APIs verwenden URLs, um Datenzugriffspunkte zu definieren, wobei mehrere Anforderungen für komplexes Datenabruf erforderlich sind. GraphQL verbessert die Effizienz, indem Clients die genauen Daten in einer einzigen Anforderung angeben können. Datenbeziehungen werden als Diagramm dargestellt, wodurch das Abheben von Daten optimiert wird.
Serverlose Architektur beseitigt die Notwendigkeit, Server zu verwalten. Sie zahlen nur für die konsumierten Ressourcen und vereinfachen die Bereitstellung und Wartung. Wir nutzen Netlify -Funktionen für diese serverlose Funktionalität.
Werkzeuge des Handels
Node.js und express: node.js ermöglicht die serverseitige JavaScript-Ausführung, während Express die API-Entwicklung mit Funktionen wie Routing und Middleware vereinfacht.
Netlify -Funktionen: Eine serverlose Plattform bietet kostenlose Bereitstellung und Skalierung von Funktionen. Netlify Dev erlaubt lokale Tests.
Projekt -Setup
Erstellen Sie ein neues Projektverzeichnis und initialisieren Sie es mit
npm init
.Installieren Sie die erforderlichen Pakete:
npm i express express-graphql graphql body-parser serverless-http netlify-cli -g
Dateistruktur und -konfiguration
-
netlify.toml
: Konfiguriert NetLify zum Erstellen und Bereitstellen. Entscheidend ist, dass es den Ort serverloser Funktionen angibt:
[bauen] command = "npm run build" Publish = "Build" Funktionen = "Funktionen"
-
/functions/api.js
: Enthält den API -Code.
api.js
-Code -Aufschlüsselung
- Abhängigkeiten importieren:
const express = require ("express"); const bodyparser = requiat ("Body-Parser"); const expressgraphql = require ("express-graphql"); const serveress = fordert ("serverless-http"); const {GraphQlSchema, GraphQLObjectType, GraphQlstring} = Request ("GraphQl");
- Initialisieren Sie Express und Serverless Wrapper:
const App = express (); module.exports.handler = serveress (App);
- Konfigurieren von Express Middleware:
app.use (bodyparser.json ()); app.use ("/", expressgraphql ({schema: schema, graphiql: true}));
- Definieren Sie das GraphQL -Schema:
const schema = new GraphQlSchema ({{ Abfrage: Neue GraphQlobjectType ({{ Name: "HelloWorld", Felder: () => ({{ Nachricht: { Typ: GraphQlstring, Resolve: () => "Hallo Welt", }, }), }), });
Lokale Entwicklung und Prüfung
Führen Sie netlify dev
in Ihrem Terminal aus. Greifen Sie auf den GraphiQL -Spielplatz unter http://localhost:8888/.netlify/functions/api
zu. Testen Sie Ihre API, indem Sie { message }
abfragen.
Einsatz
Schließen Sie Ihr Projekt zur automatischen Bereitstellung an Netlify (z. B. über GitHub) an. Netlify übernimmt das Erstellen und Bereitstellen Ihrer serverlosen Funktion.
Optional: Anfrage Umleitung
Erstellen Sie eine _redirects
-Datei in Ihrem Projektroot, um Anforderungen von /api
in Ihre Netlify -Funktion umzuleiten:
<code>/api /.netlify/functions/api 200!</code>
Dies vereinfacht den API -Zugriff.
Abschluss
Dieses Tutorial bietet eine Grundlage zum Erstellen und Bereitstellen von serverlosen GraphQL -APIs. Der Ansatz ist skalierbar und ermöglicht bei Bedarf eine komplexere API -Entwicklung. Denken Sie daran, die verknüpften Ressourcen für tiefere Tauchgänge in GraphQL und Serverless Technologies zu untersuchen. Der vollständige Quellcode ist auf GitHub verfügbar (Link im Originalartikel).
Das obige ist der detaillierte Inhalt vonErstellen serverloser GraphQL -API im Knoten mit Express und Netlify. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die CSS-Box-Shadow- und Umrisseigenschaften haben Thema gewonnen. JSON-Unterstützung in WordPress 6.1. Sei ein paar Beispiele für die Funktionsweise in realen Themen und welche Optionen wir diese Stile auf WordPress -Blöcke und Elemente anwenden müssen.

Wenn Sie kürzlich mit GraphQL gearbeitet oder seine Vor- und Nachteile überprüft haben, haben Sie zweifellos Dinge wie "GraphQL nicht unterstützen Caching" oder gehört

Die Sufelte Transition -API bietet eine Möglichkeit, Komponenten zu beleben, wenn sie das Dokument eingeben oder verlassen, einschließlich benutzerdefinierter Svelte -Übergänge.

In diesem Artikel werden wir in die Welt der Scrollbars eintauchen. Ich weiß, es klingt nicht zu glamourös, aber vertrau mir, eine gut gestaltete Seite geht Hand in Hand

Wie viel Zeit damit, die Inhaltspräsentation für Ihre Websites zu entwerfen? Wenn Sie einen neuen Blog -Beitrag schreiben oder eine neue Seite erstellen, denken Sie darüber nach

Mit dem jüngsten Aufstieg von Bitcoins Preis über 20.000 USD und kürzlich von 30.000, dachte ich, es lohnt

NPM-Befehle führen verschiedene Aufgaben für Sie aus, entweder als einmalige oder als kontinuierlich ausgeführter Vorgang für Dinge wie das Starten eines Servers oder das Kompilieren von Code.

Ich habe mich neulich mit Eric Meyer unterhalten und erinnerte mich an eine Eric Meyer -Geschichte aus meinen prägenden Jahren. Ich habe einen Blog -Beitrag über CSS -Spezifität geschrieben, und


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

MantisBT
Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

Dreamweaver CS6
Visuelle Webentwicklungstools

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung