API 网关,被 CORS 策略阻止:没有“Access-Control-Allow-Origin”标头

Car*_*nez 6 go aws-api-gateway serverless

我知道这个问题可能会重复,但是现有的问题都没有指向我没有做的任何事情......

我已经使用无服务器框架部署了一个 API,但是我在使用 CORS 时遇到了问题。

我正在使用 axios 执行 get 请求:

axios.get('https://test.execute-api.us-west-1.amazonaws.com/dev/test?from=2012-01-09T21:40:00Z')
     .then(response => {
       this.data = response.data;
     })
     .catch(error => console.log(error))
Run Code Online (Sandbox Code Playgroud)

我收到以下错误:

Access to XMLHttpRequest at 'https://test.execute-api.us-west-1.amazonaws.com/dev/test?from=2012-01-09T21:40:00Z' from origin 'http://localhost:8080' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.
Run Code Online (Sandbox Code Playgroud)

我已经做了什么:

  • 确保 API Gateway 中有一个 OPTIONS 方法,其方法响应如下所示:

在此处输入图片说明

  • 确保我部署了这些更改。

此外,我的 Lambda 函数的响应返回以下标头:

return events.APIGatewayProxyResponse{
    StatusCode: http.StatusOK,
    Headers: map[string]string{
        "Access-Control-Allow-Origin":      "http://localhost:8080",
        "Access-Control-Allow-Credentials": "true",
    },
    Body: string(jsonEvents),
}, nil
Run Code Online (Sandbox Code Playgroud)

我也尝试设置Access-Control-Allow-Origin'*'

我的 serverless.yml 文件cors: true对每个函数事件都有:

functions:
  deploymentFrequency:
    handler: bin/update/deployment-frequency
    events:
      - http:
          path: deployment-frequency
          method: post
          cors: true
  fetchDeploymentFrequency:
    handler: bin/fetch/deployment-frequency
    events:
      - http:
          path: deployment-frequency
          method: get
          cors: true
Run Code Online (Sandbox Code Playgroud)

我错过了什么?似乎没有任何效果。Postman 的请求工作正常,它看起来包含标头,所以这似乎是 OPTIONS 方法的问题。

Cle*_*ton 5

我的配置是:

(event, context, callback) => {
   callback(null, {
      statusCode: (code || 200),
      body: JSON.stringify(resp),
      headers: { 'Access-Control-Allow-Origin': '*'},
   });
}
Run Code Online (Sandbox Code Playgroud)

它对我来说很好用。我以前和你有同样的问题,但只要你用 CORS: true 定义你的函数并且你的响应包含标题,你应该没问题。

注意:我不理解语法“map[string]string”,在这种情况下不需要凭据。


Car*_*nez 3

事实证明我忽略了响应中的状态代码:(

我意识到我实际上遇到了两个错误:

  • 缺少 Content-Type 标头的 406 状态代码
  • CORS 错误

第一个错误是因为我没有将 Content-Type 标头传递给请求而引起的(我在代码中进行了检查,我完全忘记了需要该标头)。

第二个错误是因为我没有将Access-Control-Allow-Origin标头添加到函数的错误响应中而引起的。