Sie können einen Workflowschritt definieren, der einen HTTP-Aufruf durchführt, und die Antwort des Aufrufs einer Variablen zuweisen. Beispielsweise können Sie über eine HTTP-Anfrage einen Google Cloud-Dienst wie Cloud Run-Funktionen oder Cloud Run aufrufen.
HTTP-Endpunkt aufrufen
Mit diesem Schritt können Sie eine HTTP-Anfrage stellen. Sowohl HTTP- als auch HTTPS-Anfragen werden unterstützt. Die gängigsten Methoden für HTTP-Anfragen haben eine Aufrufverknüpfung wie http.get und http.post. Sie können aber eine beliebige Methode verwenden, um Typ der HTTP-Anfrage. Dazu setzen Sie das Feld call
auf http.request
und geben den Anfragetyp im Feld method
an.
YAML
- STEP_NAME: call: HTTP_REQUEST args: url: URL_VALUE method: REQUEST_METHOD private_service_name: "REGISTERED_SERVICE" headers: HEADER_KEY:HEADER_VALUE ... body: BODY_KEY:BODY_VALUE ... query: QUERY_KEY:QUERY_VALUE ... auth: type: AUTH_TYPE scope: AUTH_SCOPE scopes: AUTH_SCOPE audience: AUDIENCE timeout: TIMEOUT_IN_SECONDS result: RESULT_VALUE
JSON
[ { "STEP_NAME": { "call": "HTTP_REQUEST", "args": { "url": "URL_VALUE", "method": "REQUEST_METHOD", "private_service_name": "REGISTERED_SERVICE", "headers": {"HEADER_KEY":"HEADER_VALUE", ... }, "body": {"BODY_KEY":"BODY_VALUE", ... }, "query": {"QUERY_KEY":"QUERY_VALUE", ... }, "auth": { "type":"AUTH_TYPE", "scope":"AUTH_SCOPE", "scopes":"AUTH_SCOPE", "audience":"AUDIENCE" }, "timeout": "TIMEOUT_IN_SECONDS" }, "result": "RESULT_VALUE" } } ]
Dabei gilt:
HTTP_REQUEST
: erforderlich. Verwenden Sie eine der folgenden Optionen für HTTP-Anfragen:http.delete
http.get
http.patch
http.post
http.put
http.request
URL_VALUE
: erforderlich. URL, an die die Anfrage gesendet wird.REQUEST_METHOD
: erforderlich, wenn Sie den Aufruftyphttp.request
verwenden. Der zu verwendende HTTP-Anfragetyp. Beispiel:GET
POST
PATCH
DELETE
REGISTERED_SERVICE
: Optional. Ein registrierter Service Directory-Dienstname im Formatprojects/PROJECT_ID/locations/LOCATION/namespaces/NAMESPACE_NAME/services/SERVICE_NAME
. Weitere Informationen finden Sie unter VPC Service Controls-konformen privaten Endpunkt aufrufen.HEADER_KEY
:HEADER_VALUE
: Optional. Header-Felder für die Bereitstellung der APIWenn Sie den Medientyp des Anfragetexts mit einem
Content-Type
-Header angeben, werden nur die folgenden Typen unterstützt:application/json
oderapplication/type+json
– muss eine Karte seinapplication/x-www-form-urlencoded
– muss ein nicht codierter String seintext/type
— muss ein String sein.
Wenn ein
Content-Type
-Header angegeben ist, wird der Text wie vorgeschrieben codiert. Sie kann beispielsweise JSON- oder URL-codiert sein.Wenn Sie einen
User-Agent
-Header verwenden, um den anfragenden User-Agent zu identifizieren, gilt Folgendes:- Der Standardwert ist
GoogleCloudWorkflows; (+https://cloud.google.com/workflows/docs)
. - Wenn ein Wert angegeben ist, wird
GoogleCloudWorkflows; (+https://cloud.google.com/workflows/docs)
an diesen Wert angehängt.Wenn
User-Agent: "MY_USER_AGENT_VALUE"
beispielsweise angegeben ist, lautet der HTTP-Anfrageheader so (mit einem Leerzeichen zwischen dem angegebenen Wert und dem angehängten Standardwert):MY_USER_AGENT_VALUE GoogleCloudWorkflows; (+https://cloud.google.com/workflows/docs)
BODY_KEY
:BODY_VALUE
: optional. Textfelder zur Bereitstellung einer Eingabe für die APIWenn kein
Content-Type
-Header angegeben ist und ein Anfragetext vorhanden ist, gilt Folgendes:- Wenn der Body-Wert „bytes“ ist, wird der Header auf
Content-Type: application/octet-stream
gesetzt. - Andernfalls ist der Text JSON-codiert und der Header ist auf
Content-Type: application/json; charset=utf-8
gesetzt.
YAML
body: requests: - image: source: gcsImageUri: ${gsUri} features: - type: LABEL_DETECTION - type: SAFE_SEARCH_DETECTION - type: IMAGE_PROPERTIES result: imageAnalysisResponse
JSON
{ "requests":[ { "image": { "source": { "gcsUri": "img.png" } }, "features": [ { "type":"LABEL_DETECTION" }, { "type":"SAFE_SEARCH_DETECTION" }, { "type":"IMAGE_PROPERTIES" }, ] } ] }
- Wenn der Body-Wert „bytes“ ist, wird der Header auf
QUERY_KEY
:QUERY_VALUE
: optional. Abfragefelder zur Bereitstellung einer Eingabe für die APIAUTH_TYPE
: Optional. Erforderlich, wenn die aufgerufene API eine Authentifizierung erfordert. Verwenden Sie entwederOIDC
oderOAuth2
. Weitere Informationen finden Sie unter Authentifizierte Anfragen von einem Workflow aus ausführen.AUTH_SCOPE
: Optional. Beschränkt den Zugriff einer Anwendung auf das Konto eines Nutzers. Verwenden Sie entweder die Tastescope
oderscopes
.Der Schlüssel
scope
unterstützt entweder einen String oder eine Liste von Strings. Beispiel:"https://www.googleapis.com/auth/cloud-platform"
oder
["https://www.googleapis.com/auth/cloud-platform", "scope2", "scope3"]
Der Schlüssel
scopes
unterstützt nicht nur einen String oder eine Liste von Strings, sondern auch durch Leerzeichen und Kommas getrennte Strings. Beispiel:"https://www.googleapis.com/auth/cloud-platform scope2 scope3"
oder
"https://www.googleapis.com/auth/cloud-platform,scope2,scope3"
Weitere Informationen finden Sie unter OAuth 2.0-Bereiche für Google APIs.
AUDIENCE
: Optional. Gibt die Zielgruppe für das OIDC-Token an. Standardmäßig ist der Wert aufurl
gesetzt. Er sollte jedoch auf die Stamm-URL Ihres Dienstes festgelegt sein. Beispiel:https://region-project.cloudfunctions.net/hello_world
.
TIMEOUT_IN_SECONDS
: Optional. Die Dauer in Sekunden, die eine Anfrage ausgeführt werden darf, bevor eine Ausnahme ausgelöst wird. Das Maximum beträgt 1.800 Sekunden.RESULT_VALUE
: Optional. Variablenname, in dem das Ergebnis eines HTTP-Aufrufschritts gespeichert ist.
Auf in einer Variable gespeicherte HTTP-Antwortdaten zugreifen
Wenn in der Content-Type
-Kopfzeile für die Antwort ein application/json
-Medientyp angegeben ist, wird die in einer Variablen gespeicherte JSON-Antwort automatisch in eine Zuordnung konvertiert, auf die zugegriffen werden kann.
Ändern Sie bei Bedarf die aufgerufene API, um einen application/json
-Medientyp für den Content-Type
-Antwortheader anzugeben. Andernfalls können Sie die Funktionen json.decode
und text.encode
verwenden, um den Antworttext in eine Karte umzuwandeln. Beispiel:
json.decode(text.encode(RESPONSE_FROM_API))
Workflows enthalten einen integrierten Parser für den Zugriff auf diese Daten. Verwenden Sie die folgende Syntax, um über die HTTP-Antwort auf die Felder zuzugreifen:
${VARIABLE_NAME.body|code|headers.PATH_TO_FIELD}
Ersetzen Sie Folgendes:
VARIABLE_NAME
: Der Name der Workflowvariable, in der Sie eine JSON-Antwort gespeichert haben.body
: Verwenden Sie das Feldbody
, um auf den Text der HTTP-Antwort zuzugreifen.code
: Verwenden Sie das Feldcode
, um auf den HTTP-Antwortcode zuzugreifen.headers
: Verwenden Sie das Feldheaders
, um per Name auf die HTTP-Antwortheader zuzugreifen.PATH_TO_FIELD
: Pfad zum Feld in der JSON-Antwort, auf die Sie zugreifen möchten. Kann einfach der Name des Felds sein. Wenn das Feld in einem Objekt verschachtelt ist, kann es die Formobject1.object2.field
haben.
Wenn eine API beispielsweise {"age":50}
zurückgibt und ein Workflow diese Antwort in einer Variablen mit dem Namen age_response
speichert, gibt das folgende Beispiel den Wert des Felds age
zurück: In diesem Fall gilt 50
:
age_response.body.age
Beispiele
Diese Beispiele veranschaulichen die Syntax.
Antwort von einem API-Aufruf zuweisen
Wenn Sie keinen eigenen Suchbegriff eingeben, verwendet dieses Beispiel Ihren Google Cloud-Standort, um einen Suchbegriff zu erstellen, der an die Wikipedia API übergeben wird. Es wird eine Liste ähnlicher Wikipedia-Artikel zurückgegeben.
YAML
JSON
Externe HTTP-POST-Anfrage stellen
In diesem Beispiel wird eine POST-Anfrage an einen externen HTTP-Endpunkt gesendet.
YAML
JSON
Externe HTTP GET-Anfrage mit Headern senden
In diesem Beispiel wird eine HTTP GET-Anfrage mit einem benutzerdefinierten Header gesendet. Sie können auch benutzerdefinierte Headerdefinitionen festlegen, wenn Sie andere Arten von HTTP-Anfragen stellen.
YAML
JSON
OIDC zur Authentifizierung bei einer Anfrage an Cloud Run-Funktionen verwenden
In diesem Beispiel wird eine HTTP-Anfrage mit OIDC durch Hinzufügen einerauth
zumargs
Abschnitt der Workflow-Definition, nachdem Sie die URL angegeben haben.
YAML
JSON
HTTP-Anfragefehler abfangen und verarbeiten
In diesem Beispiel wird ein benutzerdefinierter Ausnahme-Handler basierend auf dem HTTP-Statuscode implementiert, der von der GET-Anfrage zurückgegeben wird. Der Workflow erfasst eine potenzielle Ausnahme und gibt eine vordefinierte Fehlermeldung zurück. Wenn eine Ausnahme nicht erkannt wird, schlägt die Workflowausführung fehl und die Ausnahme wird ausgegeben, die von der GET-Anfrage zurückgegeben wurde. Informationen zu anderen Fehler-Tags finden Sie unter Workflow-Fehler.
YAML
JSON
Nächste Schritte
- Anleitung: Workflows mit Cloud Run und Cloud Run-Funktionen verwenden
- VPC Service Controls-konformen privaten Endpunkt aufrufen
- Privaten On-Premise-, Compute Engine-, GKE- oder anderen Endpunkt aufrufen, indem IAP aktiviert wird
- Referenz zur Workflows-Syntax