AWS API网关自定义授权程序AuthorizerConfigurationException

时间:2016-07-28 03:06:18

标签: amazon-web-services aws-lambda aws-api-gateway custom-authentication

对于Kinesis流,我使用AWS API Gateway创建了代理API。我使用python Lambda为代理添加了一个自定义授权程序。 在发布lambda函数和部署API之后,我能够使用Gateway Test功能成功测试API。我可以看到cloudwatch中的日志,其中包含来自自定义auth lambda函数的详细打印。身份验证成功后,API Gateway将记录推送到我的Kinesis流中 但是,当我从Chrome Postman客户端调用相同的API时,我得到 500内部服务器错误,响应标​​头包含 X-Cache→来自cloudfront的错误,x-amzn-ErrorType→AuthorizerConfigurationException

Lambda auth函数返回允许对我的API执行请求的策略。返回的政策文件是:

            {
              "policyDocument": {
                "Version": "2012-10-17",
                "Statement": [
                  {
                    "Action": "execute-api:Invoke",
                    "Resource": [
                      "arn:aws:execute-api:us-east-1:1234567:myapiId/staging/POST/*"
                    ],
                    "Effect": "Allow"
                  }
                ]
              },
              "principalId": "Foo"
            }

为什么请求会因Chrome或curl而失败,但相同的API测试可以在API网关中正常运行?

4 个答案:

答案 0 :(得分:6)

AuthorizerConfigurationException 通常表示由于权限错误,API网关未能调用您的授权人。

请确保您已正确配置API网关调用的功能。通过删除功能并将其重新添加到授权程序,可以轻松重置此功能。然后控制台将提示您添加必要的权限。

答案 1 :(得分:6)

找出导致问题的原因。从python lambda函数,我返回一个json字符串实例。相反它应该是json对象。 奇怪的是,当我从API网关测试API时,相同的lambda函数没有错误#34; test"特征。但是当从互联网(curl或chrome)调用API时,它失败了。

#return policy_string ... this is incorrect.
return json.loads(policy_string)

答案 2 :(得分:0)

就我而言,我没有返回格式正确的IAM策略文档。我的Authorizer函数对如何从请求中获取一些参数做了错误的假设,并且默认结果不是正确的策略(这是我的特殊情况)。我设法使用CloudWatch日志服务对其进行了调试,其中传统的日志记录指令来自我的功能代码。

答案 3 :(得分:0)

我遇到了同样的错误,在我的例子中是一个nodejs函数,我正在添加一个上下文键作为数组。

{
  policyDocument: {
  Version: '2012-10-17',
  Statement: [{
    Action: 'execute-api:Invoke',
    Effect: effect,
    Resource: `${arn.split('/').slice(0, 2).join('/')}/*`,
  }],
},
context: {
  roles: ['admin']
}

正如医生所说:

  

您可以通过调用$ context.authorizer.stringKey,$ context访问映射模板中上下文映射的stringKey,numberKey或booleanKey值(例如,“ value”,“ 1”或“ true”) .authorizer.numberKey或$ context.authorizer.booleanKey。返回的值都被字符串化。 请注意,您无法将JSON对象或数组设置为上下文映射中任何键的有效值。

删除角色键即可使用。