Sie können eine Funktion über eine HTTP-Anfrage auslösen, indem Sie functions.https
verwenden. Dadurch können Sie eine synchrone Funktion über die folgenden unterstützten HTTP-Methoden aufrufen: GET
, POST
, PUT
, DELETE
und OPTIONS
.
Die Beispiele auf dieser Seite basieren auf einer Beispielfunktion , die ausgelöst wird, wenn Sie eine HTTP- GET
Anfrage an den Funktionsendpunkt senden. Die Beispielfunktion ruft die aktuelle Serverzeit ab, formatiert die Zeit wie in einem URL-Abfrageparameter angegeben und sendet das Ergebnis in der HTTP-Antwort.
Lösen Sie eine Funktion mit einer HTTP-Anfrage aus
Verwenden Sie functions.https
, um eine Funktion zu erstellen, die HTTP-Ereignisse verarbeitet. Der Ereignishandler für eine HTTP-Funktion wartet auf das Ereignis onRequest()
, das Router und Apps unterstützt, die vom Express- Webframework verwaltet werden.
Verwendung von Express-Anfrage- und -Antwortobjekten
Das Request- Objekt wird als Argument für onRequest()
verwendet und gibt Ihnen Zugriff auf die Eigenschaften der vom Client gesendeten HTTP-Anfrage. Das Response -Objekt bietet Ihnen die Möglichkeit, eine Antwort an den Client zurückzusenden.
exports.date = functions.https.onRequest((req, res) => { // ... });
Nutzung vorhandener Express-Apps
Mit App als Argument für onRequest()
können Sie eine vollständige Express-App an eine HTTP-Funktion übergeben. Der Boilerplate-Code kann wie gezeigt in die Middleware verschoben werden:
const express = require('express');
const cors = require('cors');
const app = express();
// Automatically allow cross-origin requests
app.use(cors({ origin: true }));
// Add middleware to authenticate requests
app.use(myMiddleware);
// build multiple CRUD interfaces:
app.get('/:id', (req, res) => res.send(Widgets.getById(req.params.id)));
app.post('/', (req, res) => res.send(Widgets.create()));
app.put('/:id', (req, res) => res.send(Widgets.update(req.params.id, req.body)));
app.delete('/:id', (req, res) => res.send(Widgets.delete(req.params.id)));
app.get('/', (req, res) => res.send(Widgets.list()));
// Expose Express API as a single Cloud Function:
exports.widgets = functions.https.onRequest(app);
Rufen Sie eine HTTP-Funktion auf
Nachdem Sie eine HTTP-Funktion bereitgestellt haben, können Sie sie über ihre eigene eindeutige URL aufrufen. Die URL enthält in der Reihenfolge Folgendes:
- Die Region (oder Regionen), in der Sie Ihre Funktion bereitgestellt haben. Einige Produktionsfunktionen müssen den Standort möglicherweise explizit festlegen, um die Netzwerklatenz zu minimieren.
- Ihre Firebase-Projekt-ID
-
cloudfunctions.net
- Der Name Ihrer Funktion
Die URL zum Aufrufen date()
sieht beispielsweise so aus:
https://us-central1-<project-id>.cloudfunctions.net/date
Wenn beim Bereitstellen von Funktionen Berechtigungsfehler auftreten, stellen Sie sicher, dass dem Benutzer, der die Bereitstellungsbefehle ausführt, die entsprechenden IAM-Rollen zugewiesen sind.
Beim Express-App-Routing wird der Funktionsname als Präfix zu den URL-Pfaden in der von Ihnen definierten App hinzugefügt. Die URL zum Aufrufen des Getters im Express-App-Beispiel oben sieht beispielsweise so aus:
https://us-central1-<project-id>.cloudfunctions.net/widgets/<id>
Wenn Sie HTTP-Funktionen hinter einer Firewall oder einem IP-Filter aufrufen, können Sie die IP-Adressen nachschlagen , die Google zur Bereitstellung von HTTP-Funktionen verwendet.
Verwenden Sie Middleware-Module mit Cloud Functions
Wenn Sie Middleware-Abhängigkeiten für Dinge wie Cookie-Unterstützung oder CORS einfügen müssen, rufen Sie diese innerhalb der Funktion auf. Um beispielsweise die CORS-Unterstützung zu aktivieren, fügen Sie den folgenden Block hinzu:
// Enable CORS using the `cors` express middleware. cors(req, res, () => { // ... });
Werte aus der Anfrage lesen
In der folgenden Tabelle sind einige häufige Szenarien aufgeführt:Inhaltstyp | Anforderungstext | Verhalten |
---|---|---|
application/json | '{"name":"John"}' | request.body.name entspricht 'John' |
application/octet-stream | 'mein Text' | request.body entspricht „6d792074657874“ (die Rohbytes der Anfrage; siehe die Node.js-Pufferdokumentation ) |
text/plain | 'mein Text' | request.body entspricht „mein Text“ |
application/x-www-form-urlencoded | 'name=John' | request.body.name entspricht 'John' |
Dieses Parsing wird von den folgenden Body-Parsern durchgeführt:
Angenommen, Ihre Funktion wird mit der folgenden Anfrage aufgerufen:
curl -X POST -H "Content-Type:application/json" -H "X-MyHeader: 123" YOUR_HTTP_TRIGGER_ENDPOINT?foo=baz -d '{"text":"something"}'
dann würden die gesendeten Daten wie folgt materialisiert werden:
Eigenschaft/Methode | Wert |
---|---|
req.method | "POST" |
req.get('x-myheader') | „123“ |
req.query.foo | „baz“ |
req.body.text | "etwas" |
req.rawBody | Die rohen (nicht geparsten) Bytes der Anfrage |
Im Beispiel der date()
-Funktion testet die Funktion sowohl den URL-Parameter als auch den Textkörper auf einen format
, um das zu verwendende Datums-/Uhrzeitformat festzulegen:
let format = req.query.format; format = req.body.format;
Beenden Sie HTTP-Funktionen
Beenden Sie eine HTTP-Funktion immer mit send()
, redirect()
oder end()
. Andernfalls wird Ihre Funktion möglicherweise weiter ausgeführt und vom System zwangsweise beendet. Siehe auch Sync, Async und Promises .
Nach dem Abrufen und Formatieren der Serverzeit mithilfe des moment
Moduls von Node.js sendet die Funktion date()
abschließend das Ergebnis in der HTTP-Antwort:
const formattedDate = moment().format(`${format}`); functions.logger.log('Sending Formatted date:', formattedDate); res.status(200).send(formattedDate);
HTTP-Funktionen mit Firebase Hosting verbinden
Sie können eine HTTP-Funktion mit Firebase Hosting verbinden. Anfragen auf Ihrer Firebase-Hosting-Site können an bestimmte HTTP-Funktionen weitergeleitet werden. Dies ermöglicht Ihnen auch die Verwendung Ihrer eigenen benutzerdefinierten Domain mit einer HTTP-Funktion. Erfahren Sie mehr über die Verbindung von Cloud Functions mit Firebase Hosting .