我有一个与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错误的情况下,'*'
的固定值是可以的,但是如何以及在何处配置?
答案 0 :(得分:0)
使用这些值在您的处理函数中添加此回调,您可以在正文中添加正确的响应
callback(null, {
statusCode: 200,
headers: {
'Content-Type': 'application/json',
"Access-Control-Allow-Headers": "*",
"Access-Control-Allow-Origin": "*",
},
body: JSON.stringify({ "response": true })
});