Rufen Sie Funktionen über HTTP-Anfragen auf


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

Als Argumente für onRequest() gibt Ihnen das Request- Objekt Zugriff auf die Eigenschaften der vom Client gesendeten HTTP-Anfrage, und 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. Bei einigen Produktionsfunktionen muss der Standort möglicherweise explizit festgelegt werden, 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 (ungeparsten) 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 .