AWS API网关:通过所有参数



我使用亚马逊中的API网关作为后端API的简单代理。使用它的主要原因是:获取API密钥以及身份验证、跟踪和处理"环境"的简单方法。

我的问题是,我们只想把所有的查询参数、头等传递给我们的后端,让它来处理它。然后在返回的路上,我们想把我们服务的适当响应代码传递给客户端;不必显式映射它们。据我所知,您几乎必须指定每个查询参数,如果参数发生更改或添加了更多,则需要更新您的api。在开发/测试过程中,这对我们来说有点乏味。

有没有一种方法可以告诉Gateway只接受并传递任何查询参数、标头等,这样您就不必显式地指定它们了?响应状态代码的问题相同?

不幸的是,没有办法对所有参数进行传递,您必须在方法请求中声明每个参数。状态代码的答案相同

此后,我们启动了HTTP端点和Lambda函数的"代理"集成,它们将充当请求输入的代理,并将所有参数和有效负载发送到集成。对于Lambda函数,有一个预构建的JSON结构,其中包含所有参数和有效载荷,以及请求上下文和阶段变量。

请参阅此文档:http://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-set-up-simple-proxy.html#api-网关在代理资源上设置lambda代理集成

这是我们过去收到的一个功能请求,它在我们的积压工作中,但目前没有ETA。我将把这作为两个直通功能的另一个+1。

对于请求,有一些映射可以轻松地通过所有内容,这是我最近使用的一个:

{
  "method": "$context.httpMethod",
  "body" : $input.json('$'),
  "headers": {
    #foreach($param in $input.params().header.keySet())
    "$param": "$util.escapeJavaScript($input.params().header.get($param))" #if($foreach.hasNext),#end
    #end
  },
  "queryParams": {
    #foreach($param in $input.params().querystring.keySet())
    "$param": "$util.escapeJavaScript($input.params().querystring.get($param))" #if($foreach.hasNext),#end
    #end
  },
  "pathParams": {
    #foreach($param in $input.params().path.keySet())
    "$param": "$util.escapeJavaScript($input.params().path.get($param))" #if($foreach.hasNext),#end
    #end
  },
  "stage-variables" : {
    #foreach($key in $stageVariables.keySet())
      "$key" : "$util.escapeJavaScript($stageVariables.get($key))"
      #if($foreach.hasNext),#end
    #end
  },
  "context" : {
    "account-id" : "$context.identity.accountId",
    "api-id" : "$context.apiId",
    "api-key" : "$context.identity.apiKey",
    "authorizer-principal-id" : "$context.authorizer.principalId",
    "caller" : "$context.identity.caller",
    "cognito-authentication-provider" : "$context.identity.cognitoAuthenticationProvider",
    "cognito-authentication-type" : "$context.identity.cognitoAuthenticationType",
    "cognito-identity-id" : "$context.identity.cognitoIdentityId",
    "cognito-identity-pool-id" : "$context.identity.cognitoIdentityPoolId",
    "http-method" : "$context.httpMethod",
    "stage" : "$context.stage",
    "source-ip" : "$context.identity.sourceIp",
    "user" : "$context.identity.user",
    "user-agent" : "$context.identity.userAgent",
    "user-arn" : "$context.identity.userArn",
    "request-id" : "$context.requestId",
    "resource-id" : "$context.resourceId",
    "resource-path" : "$context.resourcePath"
  }
}

它循环遍历所有的头和参数来映射所有内容。昨天还发布了一项新功能,允许您传递原始请求正文。

我认为您可以采用类似的方法来创建通用响应映射。您可能想看看昨天发布的parseJson()映射函数。我相信新的parseJson()函数将允许您从后端返回包含JSON数据的字符串,并将其轻松映射到API网关中的JSON响应。

我相信您可以使用API网关的http-proxy功能-它将以您发送给它的方式接收所有参数-到您提到的EC2 URL或任何其他URL

相关内容

  • 没有找到相关文章

最新更新