AWS API Gateway endpoint gives CORS error when POST from static site on S3

23,221

Solution 1

We have a bug right now where failed requests to API Gateway won't include the appropriate CORS headers, which masks the actual error on the request.

I'd add to what Ken said and make sure you've thoroughly tested the API and resources in the console and also on the deployed version using Postman or some other client that isn't a browser. I expect there is an issue with the API itself and that your CORS configuration is correct.

Solution 2

As Jack Kohn pointed out the AWS console does not add the CORS headers on non 200 response, and apparently does not allow you to add any custom header.

I was able to enable CORS headers on failed request by exporting to swagger and manually editing the file (Just copied the 200 response) and importing it back.

The responses should look like this:

  responses:
    200:
      description: "200 response"
      schema:
        $ref: "#/definitions/Empty"
      headers:
        Access-Control-Allow-Origin:
          type: "string"
    401:
      description: "401 response"
      schema:
        $ref: "#/definitions/Empty"
      headers:
        Access-Control-Allow-Origin:
          type: "string"
  x-amazon-apigateway-integration:
    responses:
      default:
        statusCode: "200"
        responseParameters:
          method.response.header.Access-Control-Allow-Origin: "'*'"
        responseTemplates:
          application/json: "__passthrough__"
      Authentication Failed.*:
        statusCode: "401"
        responseParameters:
          method.response.header.Access-Control-Allow-Origin: "'*'"
        responseTemplates:
          application/json: "__passthrough__"

Hope this helps.

Solution 3

I was struggling with the same issue when 'POST' to API Gateway. But I found the fix for the issue.

After enabling CORS for the method resource, and after adding the necessary Headers e.g. 'Access-Control-Allow-Origin' = '*' wildcard, and it still fails.

Go to OPTIONS of that resource you are invoking, 'GET', 'POST', etc..click the "Method Request" pane of that resource, set API Key = FALSE, do NOT have the API Key set to true. This will cause the CORS error.

Reason, OPTIONS is technically not a method, it a browser function to execute the Preflight request, thus during the Preflight the browser does not know what API key to send, it will know only know after the response is return to the browser of 'Access-Control-Allow-Origin' = '*' then it will look up the code for the HTTP req to setHeaders of the X-Api-Key = some value.

Note: the invoke method itself, 'POST', etc.. can have the API Key = True, which is perfectly fine.

Hope this help those who are struggling as I did for a while :)

Solution 4

I would start troubleshooting by inspecting your API in the AWS Console to make sure serverless registered everything the way you expect.

  1. Load the AWS Console and navigate to the API Gateway service.
  2. Click the API to open it up.
  3. Find your /signup resource
  4. Make sure you see the OPTIONS method under /signup
  5. Click each resource including options and check the following:

    a. Click Integration Response, click the arrow in the first row of the table for 200 to open it up.

    b. Click the arrow to open Header Mappings

    c. Make sure you see Access-Control-Allow-Origin mapped to '*'

If you find this header missing from one of the methods a quick fix is to click back on the /signup Resource and click the Enable CORS button. AWS will build out OPTIONS and the header mappings on all methods for you. Of course you still need to figure out why serverless didn't set things up for you but this will at least get you going.

Another note about the Enable CORS button, if you add another method later you'll have to click it again to re-run the tool to setup your new method with CORS.

Solution 5

I had near the same problem,as i posted in another question, I needed to add the following headers to my response:

headers: {
            'Access-Control-Allow-Origin' : '*',
            'Access-Control-Allow-Headers':'Content-Type,X-Amz-Date,Authorization,X-Api-Key,X-Amz-Security-Token',
            'Access-Control-Allow-Credentials' : true,
            'Content-Type': 'application/json'
        }

And , according to this documentation:

http://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-cors.html

When you use proxy for lambda functions on API Gateway config, the post or get methods have no added headers, only the options method does. You must do it manually in the response(server or lambda response).

Beside that, I needed to disable the 'API Key Required' option in my API gateway post method, as someone here already said.

Share:
23,221

Related videos on Youtube

Milindu Sanoj Kumarage
Author by

Milindu Sanoj Kumarage

@agentmilindu #SOreadytohelp

Updated on July 09, 2022

Comments

  • Milindu Sanoj Kumarage
    Milindu Sanoj Kumarage almost 2 years

    I have created an API endpoint with Serverless(serverless.com) which I expose through API Gateway. I'm getting following error though I have enabled CORS from the

    XMLHttpRequest cannot load https://xxxxxxxxx.execute-api.us-west-2.amazonaws.com/development/signup. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://yyyyyyyyy.com.s3-website-us-east-1.amazonaws.com' is therefore not allowed access.

    AWS API Gateway settings for the endpoint

    I don't get any errors when I use Postman to make requests, despite I have set origin header or not. How can I fix this problem?

    • Cristian Sepulveda
      Cristian Sepulveda over 6 years
      postman does not take care about CORS, then if CORS are not enabled postman still handle the request, but the browser doesn't allow the api call if CORS are not enabled.
  • Milindu Sanoj Kumarage
    Milindu Sanoj Kumarage over 8 years
    These is an OPTIONS method with Access-Control-Allow-Headers : 'Content-Type,X-Amz-Date,Authorization,X-Api-Key', Access-Control-Allow-Methods : 'POST,OPTIONS' and Access-Control-Allow-Origin : '*' set. And I see Access-Control-Allow-Origin mapped to '*' in my POST. I tied Enable CORS buttons several times.
  • Milindu Sanoj Kumarage
    Milindu Sanoj Kumarage over 8 years
    I too realized this, used an Chrome extension to enable CORS and found the actual error. But now it is fixed, web page works like a charm when CORS Chrome extension is 'On'. But still getting this No 'Access-Control-Allow-Origin' header is present on the requested resource. error when CORS Chrome extension is 'Off'. And I still don't see any 'Access-Control-Allow-Origin' in response header. I get the expected output on Postman too.
  • Jason
    Jason about 8 years
    I also recommend you look at the actual response in the browser. In Chrome, under the Network tab. This can give more details on the error
  • Ákos Vandra-Meyer
    Ákos Vandra-Meyer almost 8 years
    @jack-kohn-aws, just hit something similar, has it been fixed? It was posted months ago
  • Pompey Magnus
    Pompey Magnus almost 8 years
    @Jason your tip was a big help. I was getting this error, but it was masking a bad request underneath. Thank you.
  • turiyag
    turiyag almost 8 years
    I just spent an hour trying to figure out why your document didn't work, and it wasn't actually your document's fault, it was that I didn't Deploy the API afterward. Can you consider putting that in your document: docs.aws.amazon.com/apigateway/latest/developerguide/…
  • DccBr
    DccBr over 7 years
    "Another note about the Enable CORS button, if you add another method later you'll have to click it again to re-run the tool to setup your new method with CORS." - This is the key for my problem.
  • Adrian Parker
    Adrian Parker over 7 years
    As suggested above, my reported "No Access-Control-Allow-Origin header" error was actually being caused by a misconfigured request - in my case sending a Javascript object rather than JSON representation of same. So definitely follow the advice above - check out everything in dev tools. You may see an underlying issue.
  • Andres
    Andres over 7 years
    This helped me debugging my issue. Thank you very much. The header needs to be specified in the responses.
  • Milindu Sanoj Kumarage
    Milindu Sanoj Kumarage over 7 years
    I used a CORS enabling Chrome extension to debug the issues.
  • Doug
    Doug about 7 years
    Must re-deploy api gateway for changes to take effect as @turiyag noted.
  • Bob Kinney
    Bob Kinney almost 7 years
    Just to note: we released an update to the service to correct the bug noted by Jack: docs.aws.amazon.com/apigateway/latest/developerguide/…
  • itaylorweb
    itaylorweb about 4 years
    I was pulling my hair out for days with this issue. This was the answer that solved it for me. Thanks for posting.
  • rhmiller_ic
    rhmiller_ic over 2 years
    Make sure you deploy API after this! This solved an issue I've been having for days!