Nodejs 서버의 Ajax 요청시 CORS 정책 지정 방법 및 OPTIONS 오류 문제 해결 - Whitmem
Nodejs 서버의 Ajax 요청시 CORS 정책 지정 방법 및 OPTIONS 오류 문제 해결
NodeJS 개발
2025-05-21 00:13 게시 fb874fe86499cb737dbe

0
0
87
이 페이지는 외부 공간에 무단 복제할 수 없으며 오직 있는 그대로 게시되며 부정확한 내용을 포함할 수 있습니다. 법률이 허용하는 한 가이드 라인에 맞춰 게시 내용을 인용하거나 출처로 표기할 수 있습니다.
This page is not to be distributed to external services; it is provided as is and may contain inaccuracies.
기본적으로 CORS 는 외부 사이트에 대한 요청을 허가할 것인지 거부할 것인지에 대한 규격이라고 보면 된다.
예를 들어 사이트 A가 있고, 사이트 B가 있다고 가정한다. B는 실제 백 엔드로, API 나 어떤 실질적인 데이터를 RestAPI 등으로 제공하는 서비스라고 볼 수 있다.
이 때 A 는 Ajax 등의 동적 요청을 통해 B 사이트 주소에 요청할 수 있지만, 기본적인 정책에서는 B에 엑세스할 수 없다. 바로 브라우저의 CORS 정책 때문이다.
이는 기본적으로 A 사이트 스크립트에 포함된 악성 코드가 B 사이트로 무단으로 데이터를 반출하는 것을 방지하는데 목적이 있다.
즉 A 에서 가져온 쿠키 정보 기타 데이터 등을 B에 전송하는 걸 방지하기 위해 B의 엑세스가 거부된다.
하지만 B가 허용해야 할 대상 서버인 경우는 CORS 정책을 허용해야 한다.
기본적으로 서버가 CORS 정책을 클라이언트에게 알리기 위해 헤더에 담아서 전송하면 된다. Credentials 는 쿠키 처리를 허용하는지에 대한 여부이다. 즉 안에서 세션을 관리하는 경우 true해주면 된다.
Origin 에는 허가할 출처 사이트 메인 주소를 입력하면 된다. 만약 A -> B 접근에서 B가 A를 허용하려는 경우, B 서버에서는 A의 사이트 주소를 Origin 으로 허가하면 된다.
사이트 A에서 B에 접속하기 전 접속이 허가되는지 등의 정보를 요청하기 위해 GET, POST 가 아닌 OPTIONS 메서드로 요청을 보낸다. 그렇기 때문에 OPTIONS 접속도 허용해야 한다. 여기서 끝이 아니다. Options 요청도 허가 해야 한다.
이외 기본 인증 요청, 페이지 요청에 대한 엑세스를 허가한다.
그런데 위 헤더만 지정한 뒤 시도하여도 여전히 CORS 오류가 뜬다. 엑세스를 해서 CORS 정보를 불러올 수 없다는 식으로 오류가 뜬다. 이는 Options 로 조회하는 과정에서, Options 응답이 없기 때문이다. 보통 NodeJS 로 라우팅을 하면 GET, POST 만 라우팅하는데, Options 에 대해서도 라우팅을 하여 위 헤더 정보와 함께 성공 여부를 전송해야 한다.
즉 OPTIONS 요청이 발생한 경우 res sendStatus 를 통해 200 상태 정보를 보내어 해당 요청을 끝내야 한다. 그리고 A 클라이언트쪽에서는 해당 허가 정보를 읽고 허가된 경우 다시 GET 등의 요청을 보낼 것이다.
댓글 0개
댓글을 작성하는 경우 댓글 처리 방침에 동의하는 것으로 간주됩니다. 댓글을 작성하면 일회용 인증키가 발급되며, 해당 키를 분실하는 경우 댓글을 제거할 수 없습니다. 댓글을 작성하면 사용자 IP가 영구적으로 기록 및 부분 공개됩니다.
확인
Whitmemit 개인 일지 블로그는 개인이 운영하는 정보 공유 공간으로 사용자의 민감한 개인 정보를 직접 요구하거나 요청하지 않습니다. 기본적인 사이트 방문시 처리되는 처리 정보에 대해서는 '사이트 처리 방침'을 참고하십시오. 추가적인 기능의 제공을 위하여 쿠키 정보를 사용하고 있습니다. Whitmemit 에서 처리하는 정보는 식별 용도로 사용되며 기타 글꼴 및 폰트 라이브러리에서 쿠키 정보를 사용할 수 있습니다.
이 자료는 모두 필수 자료로 간주되며, 사이트 이용을 하거나, 탐색하는 경우 동의로 간주합니다.