Auf dieser Seite wird beschrieben, wie Sie von einer lokal ausgeführten JavaScript-Anwendung aus eine authentifizierte Anfrage an eine REST API senden, die mit Cloud Endpoints Frameworks erstellt wurde. In der JavaScript-Anwendung wird demonstriert, wie Sie Google Log-in verwenden und in der Anfrage ein Google-ID-Token zur Authentifizierung des Nutzers senden. Wenn die JavaScript-Anwendung die Anfrage sendet, authentifiziert Endpoints Frameworks diesen Nutzer und übergibt die Anfrage dann an den Back-End-Code, der in der App Engine-Standardumgebung ausgeführt wird.
Vorbereitung
So führen Sie die JavaScript-Beispielanwendung aus:
- Sie müssen die Beispiel-API aus der Anleitung Erste Schritte mit Endpoints Frameworks für Python bereitgestellt haben. Prüfen Sie, ob Sie eine erfolgreiche Antwort erhalten, wenn Sie eine Anfrage an die API senden wie unter Anfrage an die API senden beschrieben.
Suchen Sie die Google Cloud-Projekt-ID, die Sie für die Beispiel-API erstellt haben, da Sie sie zum JavaScript-Beispielcode hinzufügen müssen. Hilfe bei der Suche nach der Projekt-ID erhalten Sie unter Projekte auflisten.
Sie benötigen auf Ihrem lokalen Computer einen Webserver, um die Beispieldatei
index.html
bereitzustellen, die den JavaScript-Code enthält. Auf dieser Seite werden die Schritte zum Ausführen eines einfachen Servers mit Python beschrieben. Sie können aber jeden Webserver verwenden.
JavaScript-Clientcodebeispiel herunterladen
Klonen Sie den Beispielcode auf Ihren lokalen Rechner:
git clone https://github.com/GoogleCloudPlatform/web-docs-samples
Wechseln Sie in das Verzeichnis, das den JavaScript-Client enthält:
cd web-docs-samples/endpoints-frameworks
OAuth 2.0-Client-IDs erstellen
Damit die Beispielanwendung authentifiziert werden kann, müssen Sie im JavaScript-Beispielcode und im Back-End-Code eine OAuth 2.0-Client-ID konfigurieren. Die JavaScript-Anwendung ruft mithilfe der Client-ID ein Google-ID-Token vom OAuth 2.0-Server von Google ab und sendet dieses in der Anfrage. Endpoints Frameworks verwendet die Client-ID, um das ID-Token zu authentifizieren, das die JavaScript-Anwendung in der Anfrage gesendet hat.
So erstellen Sie eine Client-ID:
Rufen Sie in der Google Cloud Console die Seite „Anmeldedaten“ auf.
Wählen Sie aus der Projektliste das Projekt aus, das Sie für die Beispiel-API erstellt haben.
Klicken Sie auf die Schaltfläche Anmeldedaten erstellen und wählen Sie OAuth-Client-ID aus. Wenn Sie zum ersten Mal eine Client-ID in diesem Projekt erstellen, folgen Sie den Unterschritten, um einen Produktnamen auf dem Zustimmungsbildschirm festzulegen. Andernfalls können Sie mit dem nächsten Schritt fortfahren.
- Klicken Sie auf die Schaltfläche Zustimmungsbildschirm konfigurieren.
- Geben Sie im Feld Name der Anwendung einen Namen ein.
- Klicken Sie auf Speichern.
Wählen Sie unter Anwendungstyp die Option Webanwendung aus.
Geben Sie im Feld Autorisierte JavaScript-Quellen Folgendes ein:
http://localhost:8080
Klicken Sie auf Erstellen.
Kopiere deine Client-ID. Ihre vollständige Client-ID ähnelt der folgenden, ist aber eindeutig für die Webanwendung in Ihrem Projekt.
271473851874-mtll5dk2vultovbtilt31hakqbinpuvd.apps.googleusercontent.com
Weitere Informationen zum Erstellen von Client-IDs finden Sie unter OAuth 2.0 einrichten.
Back-End-Code konfigurieren und noch einmal bereitstellen
Damit Cloud Endpoints Frameworks die von der JavaScript-Anwendung gesendete Anfrage authentifizieren kann, müssen Sie die soeben erstellte Client-ID in den Beispielcode einfügen und das aktualisierte OpenAPI-Dokument sowie den Back-End-Code der Anwendung noch einmal bereitstellen.
Bei den folgenden Schritten wird davon ausgegangen, dass Sie die Beispiel-API aus der Anleitung Erste Schritte mit Endpoints Frameworks für Python bereits bereitgestellt haben. Prüfen Sie, ob Sie eine erfolgreiche Antwort erhalten, wenn Sie eine Anfrage an die API senden wie unter Anfrage an die API senden beschrieben. Beginnen Sie erst dann mit der nachfolgenden Anleitung.So konfigurieren Sie den Back-End-Code und stellen ihn noch einmal bereit:
Wechseln Sie innerhalb des Verzeichnisses, in das Sie das Repository
python-docs-samples
geklont haben, in das Verzeichnis, das das Python-Beispiel enthält:cd YOUR_WORKING_DIRECTORY/python-docs-samples/appengine/standard/endpoints-frameworks-v2/echo
Öffnen Sie die Datei
main.py
in einem Texteditor.Ersetzen Sie im Decorator für die
get_user_email
-Funktionyour-oauth-client-id.com
durch die gerade erstellte Client-ID.Speichern Sie die Datei
main.py
.Prüfen Sie, ob Sie sich im Beispielhauptverzeichnis befinden:
python-docs-samples/appengine/standard/endpoints-frameworks-v2/echo
Erstelle das YAML-Dokument neu, damit es die Client-ID enthält. Ersetze
YOUR_PROJECT_ID
im folgenden Befehl durch das Projekt, das du für die Beispiel-API erstellt hast.python lib/endpoints/endpointscfg.py get_openapi_spec main.EchoApi \ --hostname YOUR_PROJECT_ID.appspot.com
Nach dem erfolgreichen Abschluss des Vorgangs wird folgende Meldung angezeigt:
OpenAPI spec written to ./echov1openapi.json
Achten Sie darauf, dass die Google Cloud-Befehlszeile (
gcloud
) Zugriff auf Ihre Daten und Dienste in Google Cloud hat:gcloud auth login
Das Standardprojekt für die Google Cloud-Befehlszeile festlegen. Ersetzen Sie dabei
YOUR_PROJECT_ID
durch die ID des Projekts, das Sie für die Beispiel-API erstellt haben:gcloud config set project YOUR_PROJECT_ID
Stellen Sie das aktualisierte OpenAPI-Dokument bereit:
gcloud endpoints services deploy echov1openapi.json
Wenn der Befehl erfolgreich ausgeführt wurde, gibt er eine Zeile wie die folgende aus:
Service Configuration [2018-02-13r2] uploaded for service [example-project-12345.appspot.com]
Kopieren Sie die neue Dienstkonfigurations-ID.
Öffnen Sie die
app.yaml
-Datei in einem Texteditor. Ersetzen Sie den Wert des FeldesENDPOINTS_SERVICE_VERSION
durch die neue Dienstkonfigurations-ID. Beispiel:ENDPOINTS_SERVICE_NAME: example-project-12345.appspot.com ENDPOINTS_SERVICE_VERSION: 2018-02-13r2
Speichern Sie die Datei
app.yaml
.Stellen Sie den Back-End-Code noch einmal bereit:
gcloud app deploy
JavaScript-Code konfigurieren
So konfigurieren Sie den JavaScript-Code:
- Öffnen Sie die Datei
main.js
im Verzeichnisweb-docs-samples/endpoints-frameworks
in einem Texteditor. Ersetzen Sie in der Funktion
initGoogleAuth
YOUR_CLIENT_ID durch die von Ihnen erstellte Client-ID.Ersetzen Sie in der Funktion
sendSampleRequest
YOUR_PROJECT_ID durch die ID des Projekts, das Sie für die Beispiel API erstellt haben:
Authentifizierte Anfrage senden
Wechseln Sie innerhalb des Verzeichnisses, in das Sie das Repository
web-docs-samples
geklont haben, in das Verzeichnis, das das JavaScript-Beispiel enthält:cd YOUR_WORKING_DIRECTORY/web-docs-samples/endpoints-frameworks
Starten Sie Ihren Webserver für die Bereitstellung von
index.html
auf Port8080
. Im folgenden Beispiel wird der einfache Server von Python verwendet:python -m http.server 8080
Geben Sie in Ihrem Browser
localhost:8080
ein.Die JavaScript-Anwendung zeigt zwei Schaltflächen an:
Klicken Sie auf Sign In (Anmelden). Die Seite Über Google anmelden wird angezeigt.
Klicken Sie nach der Anmeldung auf die Schaltfläche Send sample request (Beispielanfrage senden). Beim ersten Senden einer Anfrage kann es zu einer Verzögerung von etwa 20 Sekunden kommen, da App Engine gestartet wird. Endpoints Frameworks fängt die Anfragen ab und verwendet die im Back-End-Code konfigurierte Client-ID, um die Anfrage zu authentifizieren. Wenn die Authentifizierung erfolgreich ist, geschieht Folgendes:
Endpoints Frameworks übergibt die Anfrage an das in App Engine ausgeführte Beispiel-Back-End.
Die Methode
get_user_email
aus dem Back-End-Code gibt die E-Mail-Adresse des Nutzerkontos zurück, das Sie bei der Anmeldung verwendet haben.Der JavaScript-Client zeigt ein Dialogfeld mit der E-Mail-Adresse an.
Überblick über den JavaScript-Client
Der JavaScript-Client verwendet Google Log-in zum Verwalten des OAuth 2.0-Ablaufs. In diesem Abschnitt erhalten Sie eine kurze Übersicht über den Code des JavaScript-Clients.
Auth
einrichten
Laden Sie die Plattformbibliothek der Google APIs, um das
gapi
-Objekt zu erstellen:Laden Sie danach die Bibliothek
auth2
:Initialisieren Sie das
GoogleAuth
-Objekt.
Beim Initialisieren des GoogleAuth
-Objekts konfigurieren Sie dieses mit Ihrer OAuth 2.0-Client-ID und den zusätzlichen Optionen, die Sie angeben möchten. Es ist üblich, den Zugriffsbereich anzugeben. Mithilfe von Bereichen wird ermöglicht, dass eine Anwendung nur für benötigte Ressourcen den Zugriff anfordern kann, während Nutzer wiederum steuern können, wie viel Zugriff sie der Anwendung gewähren. Bevor Sie mit der Implementierung der OAuth 2.0-Autorisierung beginnen, sollten Sie also die Bereiche identifizieren, für die Ihre Anwendung eine Zugriffsberechtigung benötigt. Im obigen Beispiel wird der Zugriff auf den Bereich https://www.googleapis.com/auth/userinfo.email
angefordert, wodurch das Aufrufen der E-Mail-Adresse des Nutzers ermöglicht wird.
Anmelden
Nachdem Sie das GoogleAuth
-Objekt initialisiert haben, können Sie den Nutzer zum Anmelden auffordern. Dazu rufen Sie die signIn
-Funktion des GoogleAuth
-Objekts auf:
Anfrage mit dem ID-Token stellen
Sobald der Nutzer angemeldet ist, senden Sie eine Anfrage mit einem Autorisierungsheader, der das ID-Token des Nutzers enthält: