Transfiere datos hacia y desde el servicio de backend
Cuando un cliente de API realiza una solicitud a la API implementada en API Gateway, el cliente puede pasar toda la siguiente información, como parte, de la solicitud:
- Solicita encabezados
- Parámetros de consulta
- Datos de formulario
- Cargas útiles de XML o JSON
- Rutas de solicitud
Cuando genera su respuesta a la solicitud de API, el servicio de backend puede devolver datos al cliente de la API, incluidos los siguientes:
- Encabezados de respuesta
- Cargas útiles de XML o JSON
En este documento, se describe cómo se transfieren estos datos hacia y desde el servicio de backend.
¿Cómo se pasan los datos de solicitud al servicio de backend?
Todos los datos de la solicitud del cliente de API se pasan sin cambios al servicio de backend. Luego, el servicio de backend debe analizar los datos de la solicitud como parte del procesamiento de la solicitud.
¿Cómo se devuelven los datos de respuesta al cliente de la API?
Todos los datos que se reciben en la respuesta del servicio de backend se pasan sin cambios al cliente de la API. Luego, el cliente de la API debe procesar los datos que se devuelven en la respuesta.
¿Cómo se pasa la URL de la solicitud al servicio de backend?
La extensión x-google-backend controla la URL que se usa para realizar una solicitud al servicio de backend.
En esta sección, se describen las opciones para configurar la URL del servicio de backend.
Cómo configurar la dirección y la ruta de acceso del servicio de backend en la especificación de OpenAPI
En la especificación de OpenAPI que usas para crear una configuración de API, utilizas la extensión x-google-backend para especificar la URL del servicio de backend.
Por ejemplo, puedes especificar el servicio de backend de la siguiente manera:
| Backend | x-google-backend |
|---|---|
| Cloud Run Functions | x-google-backend: address: https://GCP_REGION-PROJECT_ID.cloudfunctions.net/hello |
| Cloud Run | x-google-backend: address: https://[TAG---]SERVICE_NAME-PROJECT_NUMBER.REGION.run.app |
| Entorno estándar de App Engine | x-google-backend: address: https://PROJECT_ID.appspot.com |
En estos ejemplos, se ilustra lo siguiente:
- GCP_REGION especifica la Google Cloud región del backend implementado.
- PROJECT_ID especifica el Google Cloud ID del proyecto.
- TAG es la etiqueta de tráfico opcional para la revisión de Cloud Run que solicitas. Consulta también URL determinística en la documentación de Cloud Run.
- SERVICE_NAME es el nombre del servicio de Cloud Run.
- PROJECT_NUMBER es el Google Cloud número de proyecto.
- REGION es el nombre de la región, como
us-west1.
Además, el parámetro path en la especificación de OpenAPI especifica el extremo, o recurso, que admite tu API. Puedes especificar una ruta de acceso absoluta o una que use parámetros de ruta de acceso:
| Ruta | Ruta de acceso con parámetros |
|---|---|
paths: /hello: |
paths:
/hello/{name}: |
Cómo generar la URL del servicio de backend a partir de una solicitud a la API
Como API Gateway controla una solicitud del cliente de API, toma la URL de la solicitud que envía el cliente de la API y la traduce a la URL que se usa para realizar la solicitud al servicio de backend. La forma exacta en la que ocurre esta traducción depende de la estrategia de traducción de ruta de acceso que uses.
La opción path_translation de la extensión x-google-backend admite dos estrategias de traducción de rutas de acceso:
APPEND_PATH_TO_ADDRESS: La URL del servicio de backend se genera agregando la ruta de acceso del recurso de la solicitud del cliente a la URLaddressde la extensiónx-google-backend.La mayoría de los servicios de backend usan
APPEND_PATH_TO_ADDRESSporque significa que el backend recibe la misma ruta de recursos que especifica el cliente de la API.CONSTANT_ADDRESS: La URL del servicio de backend es constante, tal como lo define la URLaddressde la extensiónx-google-backend. Si la solicitud del cliente contiene una ruta de acceso al recurso, esta se agrega a la URL del servicio de backend con parámetros de consulta.Las funciones de Cloud Run suelen usar este método.
Por ejemplo:
APPEND_PATH_TO_ADDRESSaddress:https://PROJECT_ID.appspot.com- Sin parámetros de ruta de acceso de OpenAPI
- Ruta de acceso de OpenAPI:
/hello - Ruta de acceso del recurso de solicitud del cliente de API:
/hello - URL de la solicitud del servicio de backend:
https://PROJECT_ID.appspot.com/hello
- Ruta de acceso de OpenAPI:
- Con parámetros de ruta de acceso de OpenAPI
- Ruta de acceso de OpenAPI:
/hello/{name} - Ruta de acceso del recurso de solicitud del cliente de API:
/hello/Dave - URL de la solicitud del servicio de backend:
https://PROJECT_ID.appspot.com/hello/Dave
- Ruta de acceso de OpenAPI:
CONSTANT_ADDRESSaddress:https://GCP_REGION-PROJECT_ID.cloudfunctions.net/hello- Sin parámetros de ruta de acceso de OpenAPI
- Ruta de acceso de OpenAPI:
/hello - Ruta de acceso del recurso de solicitud del cliente de API:
/hello - URL de la solicitud del servicio de backend:
https://GCP_REGION-PROJECT_ID.cloudfunctions.net/hello
- Ruta de acceso de OpenAPI:
- Con parámetros de ruta de acceso de OpenAPI
- Ruta de acceso de OpenAPI:
/hello/{name} - Ruta de acceso del recurso de solicitud del cliente de API:
/hello/Dave - URL de la solicitud del servicio de backend:
https://GCP_REGION-PROJECT_ID.cloudfunctions.net/hello?name=Dave
- Ruta de acceso de OpenAPI:
Configura path_translation
Establece path_translation como parte de la configuración de x-google-backend:
x-google-backend: address: https://GCP_REGION-PROJECT_ID.cloudfunctions.net/hello path_translation: [ APPEND_PATH_TO_ADDRESS | CONSTANT_ADDRESS ]`
El valor predeterminado de path_translation depende de dónde establezcas x-google-backend en tu especificación de OpenAPI:
Cuando se usa
x-google-backenden el nivel superior de la especificación de OpenAPI, el valor predeterminado depath_translationesAPPEND_PATH_TO_ADDRESS.Cuando se usa
x-google-backenden el nivel de operación de la especificación de OpenAPI, el valor predeterminado depath_translationesCONSTANT_ADDRESS.