AWS API Gateway + AWS Lambda中的CORS

时间:2017-04-23 04:08:05

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

我正在尝试使用AWS Lambda和API Gateway设置POST lambda函数。这个POST应该可以使用Javascript从现代浏览器调用,所以很自然地,我需要为此启用CORS。不幸的是,无论我做什么,服务器都会在Firefox中返回400错误。我在Gateway的POST功能上启用了CORS,并设置了一个包含所有必要头文件的OPTIONS功能,但我仍然得到这个:

Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at https://ua1c36to9i.execute-api.ap-southeast-2.amazonaws.com/beta. (Reason: CORS header ‘Access-Control-Allow-Origin’ missing).

它告诉我,我没有收到Access-Control-Allow-Origin标题,我可以通过查看“广告联盟”标签中的响应来确认:

Content-Length: 181
Content-Type: application/json
Date: Sun, 23 Apr 2017 03:39:10 GMT
Via: 1.1 d0d3075c33572544a6859ec75d2258a1.cloudfront.net (CloudFront)
X-Amz-Cf-Id: EEMUjL78Bf1PSwt4E4QGPgTLXSD8sehiUCgy-XA7TC_1cKv3jxs9Rg==
X-Cache: Error from cloudfront
X-Firefox-Spdy: h2
x-amzn-RequestId: 6943b9bd-27d6-11e7-aaae-f36ce836982f

标题X-Cache: Error from cloudfront似乎告诉我Lambda必须返回某种内部服务器错误,并且CORS仅在网关上启用HTTP 200请求。实际上,我的OPTIONS预检返回HTTP 200 OK,这表明CORS似乎启用得很好。但我不知道如何用lambda捕获错误并为CORS启用它,所以我不知道我的内部错误可能是什么。

但令我感到奇怪的是,如果我使用test-cors.org测试我的POST功能,它声称我得到了一个HTTP 200 OK。更奇怪的是,如果我复制它生成的确切代码来发出请求并将其放入我本地计算机上的测试HTML页面,我仍然会获得HTTP 400。发生了什么事?

我的ajax电话:

var myData = JSON.parse(this.result);
console.log(result);
$.ajax({
    type: "POST",
    dataType: "json",
    url: "https://ua1c36to9i.execute-api.ap-southeast-2.amazonaws.com/beta",
    data: myData,
    headers: {
        "Content-Type":"application/json"
    },
    success: function (data) {
        console.log(data);
    },
    error: function (error) {
        console.log(error);
    }
});

AWS Lambda上的函数当前配置为忽略POSTed数据并只返回一个硬编码字符串,因此AJAX有效负载不重要。

1 个答案:

答案 0 :(得分:5)

您可以尝试下载AWS APIG SDK并使用apigClient执行AJAX调用,然后将标题与脚本中的标题进行比较。

看看这里:AWS API Gateway - CORS + POST not working

根据您的代码,手动设置标题特别有趣:

headers: {
     "Access-Control-Allow-Origin": "*"
},

我还建议尝试:

data: JSON.stringify(myData)

这也是一个很好的资源:https://developer.mozilla.org/en-US/docs/Web/HTTP/Access_control_CORS

我们的API服务器在AWS Beanstalk上存在CORS的一些问题,对我们来说,它归结为正确设置它们。我记得当我们最初设置它时要求清除缓存几次。