API Gateway의 REST API CORS
CORS(Cross-origin 리소스 공유)
CORS 지원 활성화 여부 확인
cross-origin HTTP 요청은 다음에 대해 이루어지는 요청입니다.
-
다른 도메인(예:
example.com
에서amazondomains.com
으로) -
다른 하위 도메인(예:
example.com
에서petstore.example.com
으로) -
다른 포트(예:
example.com
에서example.com:10777
으로) -
다른 프로토콜(예:
https://example.com
에서http://example.com
으로)
API에 액세스할 수 없고 Cross-Origin Request Blocked
가 포함된 오류 메시지를 수신하는 경우 CORS를 활성화해야 할 수 있습니다.
Cross-origin HTTP 요청은 단순 요청과 비 단순 요청의 두 가지 유형으로 나눌 수 있습니다.
단순한 요청을 위한 CORS 사용 설정
다음과 같은 모든 조건을 충족하는 HTTP 요청은 단순 요청입니다.
-
GET
,HEAD
,POST
요청만 허용하는 API 리소스에 대해 발행된 요청입니다. -
POST
메서드 요청인 경우Origin
헤더를 포함해야 합니다. -
요청 페이로드 콘텐츠 유형이
text/plain
,multipart/form-data
또는application/x-www-form-urlencoded
입니다. -
요청에 사용자 지정 헤더가 없습니다.
-
단순 요청에 대한 Mozilla CORS 문서
에 나열된 추가 요청.
간단한 교차 오리진 POST
메서드 요청의 경우 리소스의 응답에 Access-Control-Allow-Origin: '*'
또는 Access-Control-Allow-Origin:
헤더가 포함되어야 합니다.'origin'
다른 모든 cross-origin HTTP 요청은 비 단순 요청입니다.
단순하지 않은 요청을 위한 CORS 사용 설정
API 리소스가 단순하지 않은 요청을 받는 경우 통합 유형에 따라 추가 CORS 지원을 사용 설정해야 합니다.
비프록시 통합을 위한 CORS 사용 설정
이러한 통합의 경우 CORS 프로토콜
사전 요청에 대한 응답을 만드는 방법
임의 통합으로
OPTIONS
메서드를 생성합니다.-
다음 응답 헤더를 200 메서드 응답에 추가합니다.
-
Access-Control-Allow-Headers
-
Access-Control-Allow-Methods
-
Access-Control-Allow-Origin
-
-
통합 패스스루 동작을
NEVER
로 설정합니다. 이 경우 매핑되지 않은 콘텐츠 유형의 메서드 요청은 HTTP 415 미지원 미디어 유형 응답과 함께 거부됩니다. 자세한 내용은 통합 패스스루 동작 단원을 참조하십시오. -
응답 헤더의 값을 입력합니다. 모든 오리진, 모든 메서드 및 일반적인 헤더를 허용하려면 다음 헤더 값을 사용합니다.
-
Access-Control-Allow-Headers: 'Content-Type,X-Amz-Date,Authorization,X-Api-Key,X-Amz-Security-Token'
-
Access-Control-Allow-Methods: '*'
-
Access-Control-Allow-Origin: '*'
-
사전 요청을 생성한 후에는 CORS 사용이 설정된 모든 메서드에서 최소 200개 응답 모두에 대해 Access-Control-Allow-Origin: '*'
또는 Access-Control-Allow-Origin:
헤더를 반환해야 합니다.'origin'
AWS Management Console을 사용하여 비프록시 통합을 위한 CORS 사용 설정
AWS Management Console을 사용하여 CORS를 활성화할 수 있습니다. API Gateway에서 OPTIONS
메서드를 생성하고 기존 메서드 통합 응답에 Access-Control-Allow-Origin
헤더를 추가합니다. 이 방법이 항상 효과가 있는 것은 아니며, CORS 사용이 설정된 모든 메서드에서 최소 200개 응답 모두에 대해 Access-Control-Allow-Origin
헤더를 반환하도록 통합 응답을 수동으로 수정해야 하는 경우도 있습니다.
프록시 통합을 위한 CORS 지원 사용 설정
Lambda 프록시 통합 또는 HTTP 프록시 통합의 경우 프록시 통합은 통합 응답을 반환하지 않기 때문에 Access-Control-Allow-Origin
, Access-Control-Allow-Methods
, Access-Control-Allow-Headers
헤더를 반환할 책임이 백엔드에 있습니다.
다음 예제 Lambda 함수는 필요한 CORS 헤더를 반환합니다.