backend

Java Spring Boot CORS 설정 살펴보기

KUKJIN LEE
KUKJIN LEE
2025년 6월 26일
86

어떤 경우에 CORS 문제가 발생하나요?

  • 프론트엔드: https://test.com (React, Next.js 등)

  • 백엔드 API: https://api.test.com (Spring Boot)

 

서로 다른 서브도메인이라도 브라우저 기준에서는 cross-origin으로 판단하고,
백엔드 서버가 명시적으로 허용하지 않으면 CORS 에러가 발생합니다.

 

대표 에러 메시지

Access to XMLHttpRequest at 'https://api.test.com/login' 
from origin 'https://test.com' has been blocked by CORS policy:
No 'Access-Control-Allow-Origin' header is present on the requested resource.

글로벌 CORS 설정 (전체 API에 적용)

@Configuration
public class WebConfig implements WebMvcConfigurer {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**") // 전체 엔드포인트에 적용
            .allowedOrigins("https://test.com") // 허용할 프론트 주소
            .allowedMethods("GET", "POST", "PUT", "DELETE")
            .allowedHeaders("*")
            .allowCredentials(true)
            .maxAge(3600);
    }
}

글로벌 CORS 설정이 아닌 단일 CORS 설정도 가능

@CrossOrigin어노테이션 사용 (단일 컨트롤러/메서드 기준)

@CrossOrigin(origins = "https://test.com", allowCredentials = "true")
@RestController
@RequestMapping("/api")
public class UserController {
    @GetMapping("/profile")
    public User getProfile() {
        // ...
    }
}
 
  • 간단하게 적용 가능

  • 컨트롤러 단위로 제어

관련 글

[SQL 입문] 필요한 데이터만 콕 집어 가져올 수 있는 WHERE 절

사용자는 테이블에 있는 모든 데이터를 다 보고 싶어 하지는 않습니다. 오히려 특정 항목에 대한 데이터만 가져오고 싶을 때가 훨씬 많습니다. 예를 들어, 어떤 사용자의 이메일이나 ID는 알고 있는데, 그 사람이 언제 우리 앱에 가입했는지 확인하고 싶다고 가정해 봅시다...

2026년 1월 27일10

SQL에서 SELECT란 무엇인가?

데이터베이스를 거대한 서류 보관함이라고 생각하면 됩니다. 보관함 안에는 수많은 데이터가 차곡차곡 쌓입니다. SELECT는 이 보관함에서 "내가 원하는 정보를 찾아줘!"라고 요청하는 명령어입니다. 이 과정을 전문 용어로 '쿼리(Query)'라고 부릅니다. &nbs...

2026년 1월 26일10

[SQL 기초] "언제 하나씩 다 넣어?" 데이터 한 번에 넣기

개발을 하다 보면 데이터베이스(DB)에 샘플 데이터를 대량으로 넣어야 할 때가 있습니다. 메뉴 100개를 추가해야 하는데 INSERT 문을 100번 쓰고 있다면? 너무 비효율적이죠! 오늘은 SQL에서 여러 데이터를 한 번에 넣는 '다중 삽입(Multiple Inse...

2026년 1월 21일13

SQL 데이터 삽입하기

데이터가 없는 데이터베이스는 연료 없는 로켓과 같습니다. 이제 'Missions' 테이블에 새로운 행(row)을 추가하는 방법을 알아보겠습니다. "삽입(Inserting)"은 '데이터 추가'를 의미합니다. 기존 Missions 테이블 ...

2026년 1월 20일12