Tutorial: Erstellen Sie einen Rechner REST API mit zwei AWS Serviceintegrationen und einer Lambda-Non-Proxy-Integration - APIAmazon-Gateway

Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.

Tutorial: Erstellen Sie einen Rechner REST API mit zwei AWS Serviceintegrationen und einer Lambda-Non-Proxy-Integration

Das Tutorial: Erstellen Sie eine REST API Nicht-Proxy-Integration mit einer Lambda-Integration verwendet ausschließlich Lambda Function Integration. Lambda FunctionIntegration ist ein Sonderfall des AWS Service Integrationstyps, der einen Großteil der Integrationseinrichtung für Sie übernimmt, z. B. das automatische Hinzufügen der erforderlichen ressourcenbasierten Berechtigungen für den Aufruf der Lambda-Funktion. Hier wird bei zwei der drei Integrationen die AWS Service-Integration verwendet. Bei diesem Integrationstyp haben Sie mehr Kontrolle, müssen jedoch Aufgaben wie das Erstellen und Spezifizieren einer IAM Rolle mit den entsprechenden Berechtigungen manuell ausführen.

In diesem Tutorial erstellen Sie eine Calc Lambda-Funktion, die grundlegende arithmetische Operationen implementiert und JSON -formatierte Ein- und Ausgaben akzeptiert und zurückgibt. Anschließend erstellen Sie eine REST API und integrieren sie auf folgende Weise in die Lambda-Funktion:

  1. Verwenden einer GET-Methode für die /calc-Ressource, um die Lambda-Funktion aufzurufen, wobei die Eingabe als Abfragezeichenfolge-Parameter übergeben wird. (AWS Service-Integration)

  2. Verwenden einer POST-Methode für die /calc-Ressource, um die Lambda-Funktion aufzurufen, wobei die Eingabe in der Methodenanforderungsnutzlast übergeben wird. (AWS Service-Integration)

  3. Verwenden einer GET-Methode für verschachtelte /calc/{operand1}/{operand2}/{operator}-Ressourcen, um die Lambda-Funktion aufzurufen, wobei die Eingabe als Pfadparameter übergeben wird. (Lambda Function-Integration)

Zusätzlich zum Ausprobieren dieses Tutorials möchten Sie vielleicht auch die APIOpen-Definitionsdatei für studieren CalcAPI, die Sie in API Gateway importieren können, indem Sie den Anweisungen unter folgen. Entwickeln REST APIs mit Open API in API Gateway

Erstellen einer annehmbaren IAM-Rolle

Damit Sie Ihre API Calc Lambda-Funktion aufrufen können, benötigen Sie eine angenommene API IAM Gateway-Rolle, bei der es sich um eine IAM Rolle mit der folgenden vertrauenswürdigen Beziehung handelt:

{ "Version": "2012-10-17", "Statement": [ { "Sid": "", "Effect": "Allow", "Principal": { "Service": "apigateway.amazonaws.com" }, "Action": "sts:AssumeRole" } ] }

Die Rolle, die Sie erstellen, benötigt eine InvokeFunctionLambda-Berechtigung. Andernfalls erhält der API Anrufer eine 500 Internal Server Error Antwort. Um der Rolle diese Berechtigung zu erteilen, fügen Sie ihr die folgende IAM Richtlinie hinzu:

{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": "lambda:InvokeFunction", "Resource": "*" } ] }

Gehen Sie hierzu folgendermaßen vor:

Erstellen Sie eine API vermutete Rolle IAM als Gateway
  1. Anmelden bei der IAM-Konsole.

  2. Wählen Sie Roles.

  3. Wählen Sie Create Role aus.

  4. Wählen Sie unter Select type of trusted entity (Typ der vertrauenswürdigen Entität auswählen) die Option AWS Service aus.

  5. Wählen Sie unter Choose the service that will use this role (Die Rolle auswählen, die diese Rollen verwenden wird) die Option Lambda aus.

  6. Wählen Sie Next: Permissions aus.

  7. Wählen Sie Create Policy (Richtlinie erstellen) aus.

    Ein neues Create Policy Konsolen-Fenster wird geöffnet. Führen Sie in diesem Fenster folgende Schritte aus:

    1. Ersetzen Sie auf der JSONRegisterkarte die bestehende Richtlinie durch die folgende Richtlinie:

      { "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": "lambda:InvokeFunction", "Resource": "*" } ] }
    2. Wählen Sie Review policy (Richtlinie prüfen) aus.

    3. Gehen Sie unter Review Policy wie folgt vor:

      1. Geben Sie unter Name einen Namen wie lambda_execute ein.

      2. Wählen Sie Create Policy (Richtlinie erstellen) aus.

  8. Führen Sie im ursprünglichen Konsolen-Fenster Create Role Folgendes aus:

    1. Wählen Sie unter Attach permissions policies (Berechtigungsrichtlinien hinzufügen), wählen die lambda_execute Richtlinie aus der Dropdown-Liste aus.

      Wenn Ihre Richtlinie nicht in der Liste angezeigt wird, wählen Sie die Schaltfläche "Aktualisieren" oben in der Liste aus. (Aktualisieren Sie nicht die Browserseite!)

    2. Wählen Sie Next: Tags (Weiter: Tags) aus.

    3. Klicken Sie auf Weiter: Prüfen.

    4. Geben Sie unter Role name einen Namen wie lambda_invoke_function_assume_apigw_role ein.

    5. Wählen Sie Create role aus.

  9. Wählen Sie Ihre lambda_invoke_function_assume_apigw_role aus der Rollen-Liste aus.

  10. Wählen Sie die Registerkarte Trust relationships (Vertrauensstellungen).

  11. Wählen Sie Edit Trust Relationship (Vertrauensstellungen bearbeiten).

  12. Ersetzen Sie die vorhandene Richtlinie durch Folgendes:

    { "Version": "2012-10-17", "Statement": [ { "Sid": "", "Effect": "Allow", "Principal": { "Service": [ "lambda.amazonaws.com", "apigateway.amazonaws.com" ] }, "Action": "sts:AssumeRole" } ] }
  13. Wählen Sie Update Trust Policy.

  14. Notieren Sie sich die Rolle ARN für die Rolle, die Sie gerade erstellt haben. Sie benötigen sie zu einem späteren Zeitpunkt.

Erstellen einer Calc-Lambda-Funktion

Als Nächstes erstellen Sie eine Lambda-Funktion unter Verwendung der Lambda-Konsole.

  1. Wählen Sie in der Lambda-Konsole Create function (Funktion erstellen).

  2. Wählen Sie Author from scratch aus.

  3. Geben Sie als Name die Zeichenfolge „Calc“ ein.

  4. Wählen Sie für Laufzeit die neueste unterstützte Node.js- oder Python-Laufzeit aus.

  5. Verwenden Sie für alle anderen Optionen die Standardeinstellung.

  6. Wählen Sie Funktion erstellen aus.

  7. Kopieren Sie die folgende Lambda-Funktion in Ihre bevorzugte Laufzeit und fügen Sie sie in den Code-Editor in der Lambda-Konsole ein.

    Node.js
    export const handler = async function (event, context) { console.log("Received event:", JSON.stringify(event)); if ( event.a === undefined || event.b === undefined || event.op === undefined ) { return "400 Invalid Input"; } const res = {}; res.a = Number(event.a); res.b = Number(event.b); res.op = event.op; if (isNaN(event.a) || isNaN(event.b)) { return "400 Invalid Operand"; } switch (event.op) { case "+": case "add": res.c = res.a + res.b; break; case "-": case "sub": res.c = res.a - res.b; break; case "*": case "mul": res.c = res.a * res.b; break; case "/": case "div": if (res.b == 0) { return "400 Divide by Zero"; } else { res.c = res.a / res.b; } break; default: return "400 Invalid Operator"; } return res; };
    Python
    import json def lambda_handler(event, context): print(event) try: (event['a']) and (event['b']) and (event['op']) except KeyError: return '400 Invalid Input' try: res = { "a": float( event['a']), "b": float( event['b']), "op": event['op']} except ValueError: return '400 Invalid Operand' if event['op'] == '+': res['c'] = res['a'] + res['b'] elif event['op'] == '-': res['c'] = res['a'] - res['b'] elif event['op'] == '*': res['c'] = res['a'] * res['b'] elif event['op'] == '/': if res['b'] == 0: return '400 Divide by Zero' else: res['c'] = res['a'] / res['b'] else: return '400 Invalid Operator' return res
  8. Wählen Sie unter "Ausführungsrolle" Choose an existing role (Wählen Sie eine vorhandene Rolle aus) aus.

  9. Geben Sie die Rolle ARN für die lambda_invoke_function_assume_apigw_role Rolle ein, die Sie zuvor erstellt haben.

  10. Wählen Sie Deploy (Bereitstellen) aus.

Diese Funktion erfordert zwei Operanden (a und b) und einen Operator (op) aus dem Eingabeparameter event. Die Eingabe ist ein JSON Objekt mit dem folgenden Format:

{ "a": "Number" | "String", "b": "Number" | "String", "op": "String" }

Diese Funktion gibt das berechnete Ergebnis (c) und die Eingabe zurück. Im Falle einer ungültigen Eingabe gibt die Funktion entweder den Wert null (0) oder die Zeichenfolge "Invalid op" als Ergebnis zurück. Die Ausgabe hat das folgende JSON Format:

{ "a": "Number", "b": "Number", "op": "String", "c": "Number" | "String" }

Sie sollten die Funktion in der Lambda-Konsole testen, bevor Sie sie im nächsten Schritt API in die integrieren.

Calc Lambda-Funktion testen

Hier erfahren Sie, wie Sie Ihre Calc Funktion in der Lambda-Konsole testen können:

  1. Wählen Sie die Registerkarte Test.

  2. Geben Sie für den Testereignisnamen ei calc2plus5.

  3. Ersetzen Sie die Testereignisdefinition durch Folgendes:

    { "a": "2", "b": "5", "op": "+" }
  4. Wählen Sie Save (Speichern) aus.

  5. Wählen Sie Test aus.

  6. Erweitern Sie Execution result: succeeded (Ausführungsergebnis: erfolgreich). Sie sollten Folgendes sehen:

    { "a": 2, "b": 5, "op": "+", "c": 7 }

Erstellen Sie eine Calc API

Das folgende Verfahren zeigt, wie Sie eine API für die Calc Lambda-Funktion erstellen, die Sie gerade erstellt haben. In den folgenden Abschnitten fügen Sie dieser Ressourcen und Methoden hinzu.

Um eine zu erstellen API
  1. Melden Sie sich bei der API Gateway-Konsole unter https://console.aws.amazon.com/apigatewayan.

  2. Wenn Sie API Gateway zum ersten Mal verwenden, wird eine Seite angezeigt, auf der Sie mit den Funktionen des Dienstes vertraut gemacht werden. Wählen Sie RESTAPIunter Build aus. Wenn das API Popup-Fenster „Beispiel erstellen“ angezeigt wird, wählen Sie „OK“.

    Wenn Sie API Gateway nicht zum ersten Mal verwenden, wählen Sie Create API. Wählen Sie RESTAPIunter Build aus.

  3. Geben Sie als APINamen einLambdaCalc.

  4. (Optional) Geben Sie unter Description (Beschreibung) eine Beschreibung ein.

  5. Lassen Sie den APIEndpunkttyp auf Regional eingestellt.

  6. Wählen Sie Erstellen API.

Integration 1: Erstellen Sie eine GET-Methode mit Abfrageparametern, um die Lambda-Funktion aufzurufen

Indem Sie eine GET Methode erstellen, die Abfragezeichenfolgenparameter an die Lambda-Funktion übergibt, ermöglichen Sie, dass API die von einem Browser aus aufgerufen werden kann. Dieser Ansatz kann nützlich sein, insbesondere für solche, APIs die offenen Zugriff ermöglichen.

Nachdem Sie eine erstellt habenAPI, erstellen Sie eine Ressource. In der Regel werden API Ressourcen entsprechend der Anwendungslogik in einem Ressourcenbaum organisiert. In diesem Schritt erstellen Sie eine /calc-Ressource.

So erstellen Sie eine /calc-Ressource
  1. Wählen Sie Create Resource (Ressource erstellen) aus.

  2. Die Proxy-Ressource bleibt ausgeschaltet.

  3. Ressourcenpfad wird als / beibehalten.

  4. Geben Sie für Resource name (Ressourcenname) calc ein.

  5. Lassen Sie CORS(Cross Origin Resource Sharing) ausgeschaltet.

  6. Wählen Sie Create Resource (Ressource erstellen) aus.

Indem Sie eine GET Methode erstellen, die Abfragezeichenfolgenparameter an die Lambda-Funktion übergibt, ermöglichen Sie, dass API die von einem Browser aus aufgerufen werden kann. Dieser Ansatz kann nützlich sein, insbesondere für solche, APIs die offenen Zugriff ermöglichen.

Bei dieser Methode muss die POST-Anforderung verwendet wird, um eine Lambda-Funktion aufzurufen. Dieses Beispiel zeigt, dass sich die HTTP Methode in einer Frontend-Methodenanfrage von der Integrationsanforderung im Backend unterscheiden kann.

So erstellen Sie eine GET-Methode
  1. Wählen Sie die /calc-Ressource und klicken Sie dann auf Methode erstellen.

  2. Wählen Sie als Methodentyp die Option GET aus.

  3. Für Integrationstyp wählen Sie AWS-Service aus.

  4. Wählen Sie für den AWS-Region Ort aus AWS-Region, an dem Sie Ihre Lambda-Funktion erstellt haben.

  5. Wählen Sie für AWS-Service Lambda aus.

  6. Lassen Sie die AWS -Subdomain leer.

  7. Wählen Sie als HTTPMethode die Option aus POST.

  8. Wählen Sie für Aktionstyp Pfadüberschreibung verwenden aus. Diese Option ermöglicht es uns, die ARN Aktion „Aufrufen“ anzugeben, mit der unsere Calc Funktion ausgeführt werden soll.

  9. Geben Sie für Pfadüberschreibung 2015-03-31/functions/arn:aws:lambda:us-east-2:account-id:function:Calc/invocations ein. Geben Sie für account-id Ihre AWS-Konto ID ein. Geben Sie für den Ort einus-east-2, AWS-Region an dem Sie Ihre Lambda-Funktion erstellt haben.

  10. Geben Sie unter Ausführungsrolle die Rolle ARN für lambda_invoke_function_assume_apigw_role ein.

  11. Die Einstellungen für Credential-Cache und Standard-Timeout bleiben unverändert.

  12. Wählen Sie Einstellungen für Methodenanfragen aus.

  13. Wählen Sie für Anforderungs-Validator die Option Abfragezeichenfolgeparameter und -Header validieren aus.

    Mit dieser Einstellung wird eine Fehlermeldung zurückgegeben, falls der Client die erforderlichen Parameter nicht vorgibt.

  14. Wählen Sie Parameter für die URL Abfragezeichenfolge aus.

    Jetzt richten Sie Abfragezeichenfolgenparameter für die GETMethode in der /calc-Ressource ein, sodass sie Eingaben im Namen der Backend-Lambda-Funktion empfangen kann.

    Gehen Sie wie folgt vor, um die Parameter für die Abfragezeichenfolge zu erstellen:

    1. Wählen Sie Abfragezeichenfolge hinzufügen aus.

    2. Geben Sie unter Name operand1 ein.

    3. Aktivieren Sie die Option Erforderlich.

    4. Caching bleibt ausgeschaltet.

    Wiederholen Sie die obigen Schritte und erstellen Sie eine Abfragezeichenfolge mit dem Namen operand2 sowie eine Abfragezeichenfolge mit dem Namen operator.

  15. Wählen Sie Methode erstellen aus.

Als Nächstes erstellen Sie eine Zuordnungsvorlage, um die vom Client bereitgestellten Abfragezeichenfolgen wie für die Calc-Funktion erforderlich in die Integrationsanforderungs-Nutzlast zu übersetzen. Diese Vorlage ordnet die drei in Methodenanforderung deklarierten Abfragezeichenfolgenparameter den angegebenen Eigenschaftswerten des JSON Objekts als Eingabe für die Backend-Lambda-Funktion zu. Das transformierte JSON Objekt wird als Nutzlast für die Integrationsanfrage aufgenommen.

Zuordnen von Eingabeparametern zur Integrationsanforderung
  1. Klicken Sie auf der Registerkarte Integrationsanfrage unter Einstellungen für Integrationsanfragen auf Bearbeiten.

  2. Wählen Sie für Anforderungstext-Pass-Through die Option Wenn keine Vorlagen definiert sind (empfohlen) aus.

  3. Wählen Sie Zuordnungsvorlagen aus.

  4. Wählen Sie Add mapping template.

  5. Geben Sie für Content type (Inhaltstyp) application/json ein.

  6. Geben Sie für Vorlagentext den folgenden Code ein:

    { "a": "$input.params('operand1')", "b": "$input.params('operand2')", "op": "$input.params('operator')" }
  7. Wählen Sie Save (Speichern) aus.

Sie können nun Ihre GET-Methode testen, um zu verifizieren, dass sie korrekt für einen Lambda-Funktionsaufruf eingerichtet wurde.

So testen Sie die GET-Methode
  1. Wählen Sie die Registerkarte Test. Möglicherweise müssen Sie die rechte Pfeiltaste wählen, um die Registerkarte anzuzeigen.

  2. Für Abfrage-Zeichenketten geben Sie operand1=2&operand2=3&operator=+ ein.

  3. Wählen Sie Test aus.

    Die Ergebnisse sollten in etwa wie folgt aussehen:

    Erstellen Sie ein API API In-Gateway als Lambda-Proxy

Integration 2: Erstellen Sie eine POST Methode mit einer JSON Nutzlast zum Aufrufen der Lambda-Funktion

Indem Sie eine POST Methode mit einer JSON Nutzlast zum Aufrufen der Lambda-Funktion erstellen, sorgen Sie dafür, dass der Client die erforderlichen Eingaben für die Backend-Funktion im Anforderungstext bereitstellen muss. Damit sichergestellt ist, dass der Client die korrekten Eingabedaten hochlädt, aktivieren Sie die Anforderungsvalidierung für die Nutzlast.

Um eine POST Methode mit einer Nutzlast zu erstellen JSON
  1. Wählen Sie die /calc-Ressource und klicken Sie dann auf Methode erstellen.

  2. Wählen Sie als Methodentyp die Option POST aus.

  3. Für Integrationstyp wählen Sie AWS-Service aus.

  4. Wählen Sie für den AWS-Region Ort aus AWS-Region, an dem Sie Ihre Lambda-Funktion erstellt haben.

  5. Wählen Sie für AWS-Service Lambda aus.

  6. Lassen Sie die AWS -Subdomain leer.

  7. Wählen Sie als HTTPMethode die Option aus POST.

  8. Wählen Sie für Aktionstyp Pfadüberschreibung verwenden aus. Diese Option ermöglicht es uns, die ARN Aktion „Aufrufen“ anzugeben, mit der unsere Calc Funktion ausgeführt werden soll.

  9. Geben Sie für Pfadüberschreibung 2015-03-31/functions/arn:aws:lambda:us-east-2:account-id:function:Calc/invocations ein. Geben Sie für account-id Ihre AWS-Konto ID ein. Geben Sie für den Ort einus-east-2, AWS-Region an dem Sie Ihre Lambda-Funktion erstellt haben.

  10. Geben Sie unter Ausführungsrolle die Rolle ARN für lambda_invoke_function_assume_apigw_role ein.

  11. Die Einstellungen für Credential-Cache und Standard-Timeout bleiben unverändert.

  12. Wählen Sie Methode erstellen aus.

Sie können nun ein Eingabe-Modell erstellen, dasdie Struktur der Eingabedaten beschreibt und den eingehenden Anfragetext validiert.

Erstellen eines Eingabemodells
  1. Klicken Sie im Navigationsbereich auf Models (Modelle).

  2. Wählen Sie Modell erstellen aus.

  3. Geben Sie unter Name input ein.

  4. Geben Sie für Content type (Inhaltstyp) application/json ein.

    Wenn kein passender Inhaltstyp gefunden wird, wird die Anforderungsvalidierung nicht durchgeführt. Geben Sie $default ein, um das gleiche Modell unabhängig vom Inhaltstyp zu verwenden.

  5. Geben Sie für Modellschema Folgendes ein:

    { "type":"object", "properties":{ "a":{"type":"number"}, "b":{"type":"number"}, "op":{"type":"string"} }, "title":"input" }
  6. Wählen Sie Modell erstellen aus.

Als Nächstes erstellen Sie ein Ausgabe-Modell. Dieses Modell definiert die Datenstruktur der berechneten Ausgabe vom Backend. Damit werden die Integrationsantwortdaten einem anderen Modell zugewiesen. In diesem Tutorial wird das Pass-Through-Verhalten verwendet, daher wird dieses Modell nicht benötigt.

Erstellen eines Ausgabemodells
  1. Wählen Sie Modell erstellen aus.

  2. Geben Sie unter Name output ein.

  3. Geben Sie für Content type (Inhaltstyp) application/json ein.

    Wenn kein passender Inhaltstyp gefunden wird, wird die Anforderungsvalidierung nicht durchgeführt. Geben Sie $default ein, um das gleiche Modell unabhängig vom Inhaltstyp zu verwenden.

  4. Geben Sie für Modellschema Folgendes ein:

    { "type":"object", "properties":{ "c":{"type":"number"} }, "title":"output" }
  5. Wählen Sie Modell erstellen aus.

Als Nächstes erstellen Sie ein Ergebnis-Modell. Dieses Modell definiert die Datenstruktur der zurückgegebenen Antwortdaten. Es verweist sowohl auf das Eingabe - als auch auf das Ausgabeschema, das in Ihrem API definiert ist.

Erstellen eines Ergebnismodells
  1. Wählen Sie Modell erstellen aus.

  2. Geben Sie unter Name result ein.

  3. Geben Sie für Content type (Inhaltstyp) application/json ein.

    Wenn kein passender Inhaltstyp gefunden wird, wird die Anforderungsvalidierung nicht durchgeführt. Geben Sie $default ein, um das gleiche Modell unabhängig vom Inhaltstyp zu verwenden.

  4. Geben Sie für Modellschema das folgende Modell mit Ihrem ein restapi-id. Ihr restapi-id ist im folgenden Ablauf oben in der Konsole in Klammern aufgeführt: API Gateway > APIs > LambdaCalc (abc123).

    { "type":"object", "properties":{ "input":{ "$ref":"https://apigateway.amazonaws.com/restapis/restapi-id/models/input" }, "output":{ "$ref":"https://apigateway.amazonaws.com/restapis/restapi-id/models/output" } }, "title":"result" }
  5. Wählen Sie Modell erstellen aus.

Sie konfigurieren jetzt die Methodenanforderung Ihrer POST Methode so, dass die Anforderungsvalidierung für den Hauptteil der eingehenden Anfrage aktiviert wird.

Um die Anforderungsvalidierung für die POST Methode zu aktivieren
  1. Klicken Sie im Hauptnavigationsbereich auf Ressourcen und wählen Sie dann die POST-Methode in der Ressourcenstruktur aus.

  2. Wählen Sie auf der Registerkarte Methodenanfrage unter Methodenanfrage-Einstellungen die Option Bearbeiten aus.

  3. Wählen Sie für Anforderungs-Validator die Option Text validieren aus.

  4. Wählen Sie Anforderungstext aus und klicken Sie dann auf Modell hinzufügen.

  5. Geben Sie für Content type (Inhaltstyp) application/json ein.

    Wenn kein passender Inhaltstyp gefunden wird, wird die Anforderungsvalidierung nicht durchgeführt. Geben Sie $default ein, um das gleiche Modell unabhängig vom Inhaltstyp zu verwenden.

  6. Wählen Sie für Modell Eingabe aus.

  7. Wählen Sie Save (Speichern) aus.

Sie können nun Ihre POST-Methode testen, um zu verifizieren, dass sie korrekt für einen Lambda-Funktionsaufruf eingerichtet wurde.

So testen Sie die POST-Methode
  1. Wählen Sie die Registerkarte Test. Möglicherweise müssen Sie die rechte Pfeiltaste wählen, um die Registerkarte anzuzeigen.

  2. Geben Sie als Hauptteil der Anfrage die folgende JSON Nutzlast ein.

    { "a": 1, "b": 2, "op": "+" }
  3. Wählen Sie Test aus.

    Die Ausgabe sollte folgendermaßen aussehen:

    { "a": 1, "b": 2, "op": "+", "c": 3 }

Integration 3: Erstellen Sie eine GET-Methode mit Pfadparametern für den Aufruf der Lambda-Funktion

Jetzt erstellen Sie für eine Ressource eine GET-Methode, die durch eine Abfolge von Pfadparametern angegeben wird, um damit die Lambda-Funktion im Backend aufzurufen. Die Werte der Pfadparameter geben die Eingabedaten für die Lambda-Funktion an. Sie definieren eine Mapping-Vorlage, um die eingehenden Pfadparameterwerte der erforderlichen Integrationsanforderungsnutzlast zuzuweisen.

Die resultierende API Ressourcenstruktur wird wie folgt aussehen:

Erstellen Sie ein API API In-Gateway als Lambda-Proxy
Erstellen einer /{operand1}/{operand2}/{operator}-Ressource
  1. Wählen Sie Create Resource (Ressource erstellen) aus.

  2. Wählen Sie für Ressourcenpfad /calc aus.

  3. Geben Sie für Resource name (Ressourcenname) {operand1} ein.

  4. Lassen Sie CORS(Cross Origin Resource Sharing) ausgeschaltet.

  5. Wählen Sie Create Resource (Ressource erstellen) aus.

  6. Wählen Sie für Ressourcenpfad /calc/{operand1}/ aus.

  7. Geben Sie für Resource name (Ressourcenname) {operand2} ein.

  8. Halten Sie CORS(Cross-Origin Resource Sharing) ausgeschaltet.

  9. Wählen Sie Create Resource (Ressource erstellen) aus.

  10. Wählen Sie für Ressourcenpfad /calc/{operand1}/{operand2}/ aus.

  11. Geben Sie für Resource name (Ressourcenname) {operator} ein.

  12. Halten Sie CORS(Cross-Origin Resource Sharing) ausgeschaltet.

  13. Wählen Sie Create Resource (Ressource erstellen) aus.

Dieses Mal verwenden Sie die integrierte Lambda-Integration in der API Gateway-Konsole, um die Methodenintegration einzurichten.

Einrichten einer Integrationsmethode
  1. Wählen Sie die /{operand1}/{operand2}/{operator}-Ressource aus und klicken Sie dann auf Methode erstellen.

  2. Wählen Sie als Methodentyp die Option GET aus.

  3. Wählen Sie für den Integrationstyp die Option Lambda aus.

  4. Lassen Sie Lambda proxy integration (Lambda-Proxyintegration) deaktiviert.

  5. Wählen Sie für Lambda-Funktion den Ort aus, AWS-Region an dem Sie Ihre Lambda-Funktion erstellt haben, und geben Sie ein. Calc

  6. Das Standard-Timeout bleibt aktiviert.

  7. Wählen Sie Methode erstellen aus.

Sie erstellen jetzt eine Zuordnungsvorlage, um die drei URL Pfadparameter, die bei der Erstellung der Ressource /calc/ {operand1}/{operand2}/{operator} deklariert wurden, bestimmten Eigenschaftswerten im Objekt zuzuordnen. JSON Da URL Pfade URL -kodiert sein müssen, muss der Divisionsoperator anstelle von als angegeben werden. %2F / Diese Vorlage übersetzt den %2F in '/', bevor er an die Lambda-Funktion übergeben wird.

Erstellen einer Zuweisungsvorlage
  1. Klicken Sie auf der Registerkarte Integrationsanfrage unter Einstellungen für Integrationsanfragen auf Bearbeiten.

  2. Wählen Sie für Anforderungstext-Pass-Through die Option Wenn keine Vorlagen definiert sind (empfohlen) aus.

  3. Klicken Sie auf Zuordnungsvorlage hinzufügen.

  4. Geben Sie für Content type (Inhaltstyp) application/json ein.

  5. Geben Sie für Vorlagentext den folgenden Code ein:

    { "a": "$input.params('operand1')", "b": "$input.params('operand2')", "op": #if($input.params('operator')=='%2F')"/"#{else}"$input.params('operator')"#end }
  6. Wählen Sie Save (Speichern) aus.

Sie können nun Ihre GET-Methode testen, um zu verifizieren, dass sie korrekt für den Aufruf der Lambda-Funktion eingerichtet wurde, und dass die ursprüngliche Ausgabe ohne Zuweisung durch die Integrationsantwort weitergegeben wird.

So testen Sie die GET-Methode
  1. Wählen Sie die Registerkarte Test. Möglicherweise müssen Sie die rechte Pfeiltaste wählen, um die Registerkarte anzuzeigen.

  2. Für Pfad gehen Sie wie folgt vor:

    1. Geben Sie für operand1 1 ein.

    2. Geben Sie für operand2 1 ein.

    3. Geben Sie für operator + ein.

  3. Wählen Sie Test aus.

  4. Das Ergebnis sollte wie folgt aussehen:

    Testen Sie die GET Methode in der API Gateway-Konsole.

Als Nächstes modellieren Sie die Datenstruktur für die Nutzlast der Methodenantwort nach dem result-Schema.

Standardmäßig wird dem Methodenantworttext ein leeres Modell zugeordnet. Dadurch wird der Integrationsantworttext ohne Zuweisung übergeben. Wenn Sie jedoch eine SDK für eine der stark typisierten Sprachen wie Java oder Objective-C generieren, erhalten Ihre SDK Benutzer als Ergebnis ein leeres Objekt. Um sicherzustellen, dass sowohl der REST Client als auch die SDK Clients das gewünschte Ergebnis erhalten, müssen Sie die Antwortdaten anhand eines vordefinierten Schemas modellieren. Nachfolgend definieren Sie ein Modell für den Methodenantworttext und zum Erstellen einer Mapping-Vorlage, mit der der Integrationsantworttext in den Methodenantworttext umgewandelt wird.

Erstellen einer Methodenantwort
  1. Klicken Sie auf der Registerkarte Methodenantwort unter Antwort 200 auf Bearbeiten.

  2. Klicken Sie unter Anforderungstext auf Modell hinzufügen.

  3. Geben Sie für Content type (Inhaltstyp) application/json ein.

  4. Wählen Sie für Modell Ergebnis aus.

  5. Wählen Sie Save (Speichern) aus.

Wenn Sie das Modell für den Antworttext der Methode festlegen, wird sichergestellt, dass die Antwortdaten in das result Objekt eines bestimmten Objekts umgewandelt werdenSDK. Um sicherzustellen, dass die Integrationsantwortdaten entsprechend zugewiesen werden, benötigen Sie eine Mapping-Vorlage.

Erstellen einer Zuweisungsvorlage
  1. Klicken Sie auf der Registerkarte Integrationsantwort unter Standard - Antwort auf Bearbeiten.

  2. Klicken Sie auf Zuordnungsvorlage hinzufügen.

  3. Geben Sie für Content type (Inhaltstyp) application/json ein.

  4. Geben Sie für Vorlagentext den folgenden Code ein:

    #set($inputRoot = $input.path('$')) { "input" : { "a" : $inputRoot.a, "b" : $inputRoot.b, "op" : "$inputRoot.op" }, "output" : { "c" : $inputRoot.c } }
  5. Wählen Sie Save (Speichern) aus.

Testen der Zuweisungsvorlage
  1. Wählen Sie die Registerkarte Test. Möglicherweise müssen Sie die rechte Pfeiltaste wählen, um die Registerkarte anzuzeigen.

  2. Für Pfad gehen Sie wie folgt vor:

    1. Geben Sie für operand1 1 ein.

    2. Geben Sie für operand2 2 ein.

    3. Geben Sie für operator + ein.

  3. Wählen Sie Test aus.

  4. Die Antwort wird wie folgt aussehen:

    { "input": { "a": 1, "b": 2, "op": "+" }, "output": { "c": 3 } }

Derzeit können Sie die Testfunktion nur API mithilfe der Testfunktion in der API Gateway-Konsole aufrufen. Um es für Clients verfügbar zu machen, müssen Sie Ihre bereitstellenAPI. Stellen Sie immer sicher, dass Sie Ihre erneut bereitstellen, API wenn Sie eine Ressource oder Methode hinzufügen, ändern oder löschen, eine Datenzuordnung aktualisieren oder die Stufeneinstellungen aktualisieren. Andernfalls sind neue Funktionen oder Updates für Ihre API Kunden nicht verfügbar, und zwar wie folgt:

So stellen Sie die API bereit
  1. Wählen Sie BereitstellenAPI aus.

  2. Wählen Sie für Stufe die Option Neue Stufe aus.

  3. Geben Sie für Stage name (Stufenname) Prod ein.

  4. (Optional) Geben Sie unter Description (Beschreibung) eine Beschreibung ein.

  5. Wählen Sie Bereitstellen.

  6. (Optional) Unter Stage-Details können Sie für Invoke das Kopiersymbol auswählenURL, um Ihren API eigenen Aufruf URL zu kopieren. Sie können dies mit Tools wie Postman und c verwenden, um Ihre URL zu testen. API

Anmerkung

Stellen Sie Ihre immer erneut bereit, API wenn Sie eine Ressource oder Methode hinzufügen, ändern oder löschen, eine Datenzuordnung aktualisieren oder die Staging-Einstellungen aktualisieren. Andernfalls stehen Ihren API Kunden keine neuen Funktionen oder Updates zur Verfügung.