【发布时间】:2017-04-25 22:11:50
【问题描述】:
我已经像这样定义了我的AWS::ApiGateway::Method
GetOrdersMethod:
Type: "AWS::ApiGateway::Method"
Properties:
ApiKeyRequired: true
AuthorizationType: "AWS_IAM"
HttpMethod: "GET"
RequestParameters:
method.request.querystring.orderId: false
ResourceId:
Ref: "GetOrdersPathResource"
RestApiId:
Ref: "GetOrders"
Integration:
Type: "AWS_PROXY"
IntegrationHttpMethod: "POST"
RequestTemplates:
application/json: !Join ["", ["{","\"orderId\": \"$input.params('orderId')\"","}"]]
Uri: !Join ["", ["arn:aws:apigateway:", !Ref "AWS::Region", ":lambda:path/2015-03-31/functions/",!GetAtt GetProgramsLambdaFunction.Arn, "/invocations"]]
我的处理程序是这样定义的
public class ProgramHandler implements RequestHandler<Request, String>{
private LambdaLogger logger;
@Override
public String handleRequest(Request request, Context context) {
logger = context.getLogger();
logger.log("FROM LOGGER: ======= LAMBDA INVOKED ======");
logger.log("Input value: " +request.getOrderId());
System.out.println("======= LAMBDA INVOKED ======");
System.out.println("Input value: " +request.getMarketplaceId());
return "Lambda Invoked successfully";
}
}
Request 是一个简单的 java pojo,只有 orderId 作为具有必要 GETTERS 和 SETTERS 的字段
当我测试 API 网关时,我看到在我的 lambda 日志中,订单 ID 为空。但是,我确实看到它在日志中作为查询字符串传递......这里是
Tue Apr 25 21:57:31 UTC 2017 : Endpoint request body after transformations: {"resource":"/xxxx","path":"/xxxx","httpMethod":"GET","headers":null,"queryStringParameters":{"orderId":"32"},"pathParameters":null,"stageVariables":null,"requestContext":{"accountId":"xxxxxxx","resourceId":"xxxxx","stage":"test-invoke-stage", ... }
为什么我的handler 中的orderId 为空?
【问题讨论】:
标签: java amazon-web-services lambda aws-api-gateway