使用Lambda代理集成在API网关的5XX响应中添加CORS头

时间:2018-05-02 15:07:10

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

我有一个与API网关的Lambda代理集成,工作正常。

CORS直接在lambda代码中处理,并检查授权域列表。

但现在问题是Lambda执行期间出现意外错误。

在这种情况下,API网关会返回以下消息:

{
    message: "Internal server error"
}
带有502 HTTP状态代码的

。对我来说不幸的是,该响应中缺少Access-Control-Allow-Origin标头,这会导致客户端出错。

例如,超时也会发生同样的情况。然后,HTTP状态代码为504,但响应内容和Access-Control-Allow-Origin的缺失相同。

在权限问题的情况下也会出现同样的问题:如果API网关没有足够的权限来调用Lambda,则会返回500错误,但是会再次出现没有任何标头的错误。

在Lambda错误的情况下,'*'的固定值是可以的,但是如何以及在何处配置?

1 个答案:

答案 0 :(得分:0)

使用这些值在您的处理函数中添加此回调,您可以在正文中添加正确的响应

callback(null, {
      statusCode: 200,
      headers: {
          'Content-Type': 'application/json',
          "Access-Control-Allow-Headers": "*",
          "Access-Control-Allow-Origin": "*",
      },
      body: JSON.stringify({ "response": true })
    });