API Gateway 中 REST API 的参数映射示例
以下示例显示如何使用 API Gateway 控制台、OpenAPI 和 AWS CloudFormation 模板创建参数映射表达式。有关如何使用参数映射来创建所需 CORS 标头的示例,请参阅针对 API Gateway 中的 REST API 的 CORS。
示例 1:将方法请求参数映射到集成请求参数
以下示例将方法请求标头参数 puppies 映射到集成请求标头参数 DogsAge0。
- AWS Management Console
- 
          映射方法请求参数- 通过以下网址登录到 Amazon API Gateway 控制台:https://console.aws.amazon.com/apigateway - 。 
- 选择一个 REST API。 
- 选择方法。 - 您的方法必须具有非代理集成。 
- 
              对于方法请求设置,选择编辑。 
- 选择 HTTP 请求标头。 
- 选择添加标头。 
- 对于名称,请输入 - puppies。
- 选择保存。 
- 
              选择集成请求选项卡,然后对于集成请求设置,选择编辑。 AWS Management Console会自动为您添加从 method.request.header.puppies到puppies的参数映射,但您需要更改名称,以匹配集成端点所期望的请求标头参数。
- 
              对于名称,请输入 DogsAge0。
- 选择保存。 
- 重新部署 API 以使更改生效。 
 以下步骤向您展示如何验证参数映射是否成功。 (可选)测试参数映射- 选择测试选项卡。您可能需要选择右箭头按钮,以显示该选项卡。 
- 对于标头,输入 - puppies:true。
- 选择测试。 
- 在日志中,结果应该类似以下内容: - Tue Feb 04 00:28:36 UTC 2025 : Method request headers: {puppies=true} Tue Feb 04 00:28:36 UTC 2025 : Method request body before transformations: Tue Feb 04 00:28:36 UTC 2025 : Endpoint request URI: http://petstore-demo-endpoint.execute-api.com/petstore/pets Tue Feb 04 00:28:36 UTC 2025 : Endpoint request headers: {DogsAge0=true, x-amzn-apigateway-api-id=abcd1234, Accept=application/json, User-Agent=AmazonAPIGateway_aaaaaaa, X-Amzn-Trace-Id=Root=1-abcd-12344}- 请求标头参数已从 - puppies更改为- DogsAge0。
 
- AWS CloudFormation
- 
        在此示例中,您使用 body 属性将 OpenAPI 定义文件导入到 API Gateway。 AWSTemplateFormatVersion: 2010-09-09 Resources: Api: Type: 'AWS::ApiGateway::RestApi' Properties: Body: openapi: 3.0.1 info: title: ParameterMappingExample version: "2025-02-04T00:30:41Z" paths: /pets: get: parameters: - name: puppies in: header schema: type: string responses: "200": description: 200 response x-amazon-apigateway-integration: httpMethod: GET uri: http://petstore-demo-endpoint.execute-api.com/petstore/pets responses: default: statusCode: "200" requestParameters: integration.request.header.DogsAge0: method.request.header.puppies passthroughBehavior: when_no_match type: http ApiGatewayDeployment: Type: 'AWS::ApiGateway::Deployment' DependsOn: Api Properties: RestApiId: !Ref Api ApiGatewayDeployment20250219: Type: 'AWS::ApiGateway::Deployment' DependsOn: Api Properties: RestApiId: !Ref Api Stage: Type: 'AWS::ApiGateway::Stage' Properties: DeploymentId: !Ref ApiGatewayDeployment20250219 RestApiId: !Ref Api StageName: prod
- OpenAPI
- 
         { "openapi" : "3.0.1", "info" : { "title" : "ParameterMappingExample", "version" : "2025-02-04T00:30:41Z" }, "paths" : { "/pets" : { "get" : { "parameters" : [ { "name" : "puppies", "in" : "header", "schema" : { "type" : "string" } } ], "responses" : { "200" : { "description" : "200 response" } }, "x-amazon-apigateway-integration" : { "httpMethod" : "GET", "uri" : "http://petstore-demo-endpoint.execute-api.com/petstore/pets", "responses" : { "default" : { "statusCode" : "200" } }, "requestParameters" : { "integration.request.header.DogsAge0" : "method.request.header.puppies" }, "passthroughBehavior" : "when_no_match", "type" : "http" } } } } }
示例 2:将多个方法请求参数映射到不同的集成请求参数
以下示例将多值方法请求查询字符串参数 methodRequestQueryParam 映射到集成请求查询字符串参数 integrationQueryParam,并将方法请求标头参数 methodRequestHeaderParam 映射到集成请求路径参数 integrationPathParam。
- AWS Management Console
- 
      映射方法请求参数- 通过以下网址登录到 Amazon API Gateway 控制台:https://console.aws.amazon.com/apigateway - 。 
- 选择一个 REST API。 
- 选择方法。 - 您的方法必须具有非代理集成。 
- 
          对于方法请求设置,选择编辑。 
- 选择 URL 查询字符串参数。 
- 选择添加查询字符串。 
- 在名称中,输入 - methodRequestQueryParam。
- 选择 HTTP 请求标头。 
- 选择添加标头。 
- 对于名称,请输入 - methodRequestHeaderParam。
- 选择保存。 
- 
            选择集成请求选项卡,然后对于集成请求设置,选择编辑。 
- 选择 URL 路径参数。 
- 选择添加路径参数。 
- 
            对于名称,请输入 integrationPathParam。
- 对于映射自,输入 - method.request.header.methodRequestHeaderParam。- 这会将您在方法请求中指定的方法请求标头映射到新的集成请求路径参数。 
- 选择 URL 查询字符串参数。 
- 选择添加查询字符串。 
- 
          在名称中,输入 integrationQueryParam。
- 对于映射自,输入 - method.request.multivaluequerystring.methodRequestQueryParam。- 这会将多值查询字符串参数映射到新的单值集成请求查询字符串参数。 
- 选择保存。 
- 重新部署 API 以使更改生效。 
 
- AWS CloudFormation
- 在此示例中,您使用 body 属性将 OpenAPI 定义文件导入到 API Gateway。 - 以下 OpenAPI 定义为 HTTP 集成创建以下参数映射: - 
            将方法请求的名为 methodRequestHeaderParam的标头映射到名为integrationPathParam的集成请求路径参数
- 
            将名为 methodRequestQueryParam的多值方法请求查询字符串映射到名为integrationQueryParam的集成请求查询字符串
 - AWSTemplateFormatVersion: 2010-09-09 Resources: Api: Type: 'AWS::ApiGateway::RestApi' Properties: Body: openapi: 3.0.1 info: title: Parameter mapping example 2 version: "2025-01-15T19:12:31Z" paths: /: post: parameters: - name: methodRequestQueryParam in: query schema: type: string - name: methodRequestHeaderParam in: header schema: type: string responses: "200": description: 200 response x-amazon-apigateway-integration: httpMethod: GET uri: http://petstore-demo-endpoint.execute-api.com/petstore/pets responses: default: statusCode: "200" requestParameters: integration.request.querystring.integrationQueryParam: method.request.multivaluequerystring.methodRequestQueryParam integration.request.path.integrationPathParam: method.request.header.methodRequestHeaderParam requestTemplates: application/json: '{"statusCode": 200}' passthroughBehavior: when_no_templates timeoutInMillis: 29000 type: http ApiGatewayDeployment: Type: 'AWS::ApiGateway::Deployment' DependsOn: Api Properties: RestApiId: !Ref Api ApiGatewayDeployment20250219: Type: 'AWS::ApiGateway::Deployment' DependsOn: Api Properties: RestApiId: !Ref Api Stage: Type: 'AWS::ApiGateway::Stage' Properties: DeploymentId: !Ref ApiGatewayDeployment20250219 RestApiId: !Ref Api StageName: prod
- 
            
- OpenAPI
- 
          以下 OpenAPI 定义为 HTTP 集成创建以下参数映射: - 
            将方法请求的名为 methodRequestHeaderParam的标头映射到名为integrationPathParam的集成请求路径参数
- 
            将名为 methodRequestQueryParam的多值方法请求查询字符串映射到名为integrationQueryParam的集成请求查询字符串
 { "openapi" : "3.0.1", "info" : { "title" : "Parameter mapping example 2", "version" : "2025-01-15T19:12:31Z" }, "paths" : { "/" : { "post" : { "parameters" : [ { "name" : "methodRequestQueryParam", "in" : "query", "schema" : { "type" : "string" } }, { "name" : "methodRequestHeaderParam", "in" : "header", "schema" : { "type" : "string" } } ], "responses" : { "200" : { "description" : "200 response" } }, "x-amazon-apigateway-integration" : { "httpMethod" : "GET", "uri" : "http://petstore-demo-endpoint.execute-api.com/petstore/pets", "responses" : { "default" : { "statusCode" : "200" } }, "requestParameters" : { "integration.request.querystring.integrationQueryParam" : "method.request.multivaluequerystring.methodRequestQueryParam", "integration.request.path.integrationPathParam" : "method.request.header.methodRequestHeaderParam" }, "requestTemplates" : { "application/json" : "{\"statusCode\": 200}" }, "passthroughBehavior" : "when_no_templates", "timeoutInMillis" : 29000, "type" : "http" } } } } }
- 
            
示例 3:将 JSON 请求正文中的字段映射到集成请求参数
还可以使用 JSONPath expressionbody-header 的集成请求标头,并将部分请求正文(由 JSON 表达式表示)映射到名为 pet-price 的集成请求标头。
要测试此示例,请提供包含价格类别的输入,如下所示:
[ { "id": 1, "type": "dog", "price": 249.99 } ]
- AWS Management Console
- 
        映射方法请求参数- 通过以下网址登录到 Amazon API Gateway 控制台:https://console.aws.amazon.com/apigateway - 。 
- 选择一个 REST API。 
- 
              选择 POST、PUT、PATCH或ANY方法。您的方法必须具有非代理集成。 
- 
            对于集成请求设置,选择编辑。 
- 选择 URL 请求标头参数。 
- 选择添加请求标头参数。 
- 
            对于名称,请输入 body-header。
- 对于映射自,输入 - method.request.body。- 这会将方法请求正文映射到新的集成请求标头参数。 
- 选择添加请求标头参数。 
- 
          对于名称,请输入 pet-price。
- 对于映射自,输入 - method.request.body[0].price。- 这会将方法请求正文的一部分映射到新的集成请求标头参数。 
- 选择保存。 
- 重新部署 API 以使更改生效。 
 
- AWS CloudFormation
- 
        在此示例中,您使用 body 属性将 OpenAPI 定义文件导入到 API Gateway。 AWSTemplateFormatVersion: 2010-09-09 Resources: Api: Type: 'AWS::ApiGateway::RestApi' Properties: Body: openapi: 3.0.1 info: title: Parameter mapping example 3 version: "2025-01-15T19:19:14Z" paths: /: post: responses: "200": description: 200 response x-amazon-apigateway-integration: httpMethod: GET uri: http://petstore-demo-endpoint.execute-api.com/petstore/pets responses: default: statusCode: "200" requestParameters: integration.request.header.pet-price: method.request.body[0].price integration.request.header.body-header: method.request.body requestTemplates: application/json: '{"statusCode": 200}' passthroughBehavior: when_no_templates timeoutInMillis: 29000 type: http ApiGatewayDeployment: Type: 'AWS::ApiGateway::Deployment' DependsOn: Api Properties: RestApiId: !Ref Api ApiGatewayDeployment20250219: Type: 'AWS::ApiGateway::Deployment' DependsOn: Api Properties: RestApiId: !Ref Api Stage: Type: 'AWS::ApiGateway::Stage' Properties: DeploymentId: !Ref ApiGatewayDeployment20250219 RestApiId: !Ref Api StageName: prod
- OpenAPI
- 
        以下 OpenAPI 定义从 JSON 请求正文中的字段映射集成请求参数。 { "openapi" : "3.0.1", "info" : { "title" : "Parameter mapping example 3", "version" : "2025-01-15T19:19:14Z" }, "paths" : { "/" : { "post" : { "responses" : { "200" : { "description" : "200 response" } }, "x-amazon-apigateway-integration" : { "httpMethod" : "GET", "uri" : "http://petstore-demo-endpoint.execute-api.com/petstore/pets", "responses" : { "default" : { "statusCode" : "200" } }, "requestParameters" : { "integration.request.header.pet-price" : "method.request.body[0].price", "integration.request.header.body-header" : "method.request.body" }, "requestTemplates" : { "application/json" : "{\"statusCode\": 200}" }, "passthroughBehavior" : "when_no_templates", "timeoutInMillis" : 29000, "type" : "http" } } } } }
示例 4:将集成响应映射到方法响应
还可以将集成响应映射到方法响应。以下示例将集成响应正文映射到名为 location 的方法响应标头,将集成响应标头 x-app-id 映射到方法响应标头 id,并将多值集成响应标头 item 映射到方法响应标头 items。
- AWS Management Console
- 
      映射集成响应- 通过以下网址登录到 Amazon API Gateway 控制台:https://console.aws.amazon.com/apigateway - 。 
- 选择一个 REST API。 
- 选择方法。 - 您的方法必须具有非代理集成。 
- 
          选择方法响应选项卡,然后对于响应 200 选择编辑。 
- 对于标头名称,选择添加标头。 
- 创建三个名为 - id、- item、和- location的标头。
- 选择保存。 
- 
          选择集成响应选项卡,然后对于默认 - 响应,选择编辑。 
- 在标头映射下,输入以下内容。 - 对于 id,输入 - integration.response.header.x-app-id
- 对于项目,输入 - integration.response.multivalueheader.item
- 对于位置,输入 - integration.response.body.redirect.url
 
- 
          选择保存。 
- 重新部署 API 以使更改生效。 
 
- AWS CloudFormation
- 
          在此示例中,您使用 body 属性将 OpenAPI 定义文件导入到 API Gateway。 AWSTemplateFormatVersion: 2010-09-09 Resources: Api: Type: 'AWS::ApiGateway::RestApi' Properties: Body: openapi: 3.0.1 info: title: Parameter mapping example version: "2025-01-15T19:21:35Z" paths: /: post: responses: "200": description: 200 response headers: item: schema: type: string location: schema: type: string id: schema: type: string x-amazon-apigateway-integration: type: http httpMethod: GET uri: http://petstore-demo-endpoint.execute-api.com/petstore/pets responses: default: statusCode: "200" responseParameters: method.response.header.id: integration.response.header.x-app-id method.response.header.location: integration.response.body.redirect.url method.response.header.item: integration.response.multivalueheader.item requestTemplates: application/json: '{"statusCode": 200}' passthroughBehavior: when_no_templates timeoutInMillis: 29000 ApiGatewayDeployment: Type: 'AWS::ApiGateway::Deployment' DependsOn: Api Properties: RestApiId: !Ref Api ApiGatewayDeployment20250219: Type: 'AWS::ApiGateway::Deployment' DependsOn: Api Properties: RestApiId: !Ref Api Stage: Type: 'AWS::ApiGateway::Stage' Properties: DeploymentId: !Ref ApiGatewayDeployment20250219 RestApiId: !Ref Api StageName: prod
- OpenAPI
- 
      以下 OpenAPI 定义将集成响应映射到方法响应。 { "openapi" : "3.0.1", "info" : { "title" : "Parameter mapping example", "version" : "2025-01-15T19:21:35Z" }, "paths" : { "/" : { "post" : { "responses" : { "200" : { "description" : "200 response", "headers" : { "item" : { "schema" : { "type" : "string" } }, "location" : { "schema" : { "type" : "string" } }, "id" : { "schema" : { "type" : "string" } } } } }, "x-amazon-apigateway-integration" : { "type" : "http", "httpMethod" : "GET", "uri" : "http://petstore-demo-endpoint.execute-api.com/petstore/pets", "responses" : { "default" : { "statusCode" : "200", "responseParameters" : { "method.response.header.id" : "integration.response.header.x-app-id", "method.response.header.location" : "integration.response.body.redirect.url", "method.response.header.item" : "integration.response.multivalueheader.item" } } }, "requestTemplates" : { "application/json" : "{\"statusCode\": 200}" }, "passthroughBehavior" : "when_no_templates", "timeoutInMillis" : 29000 } } } } }