>Java >java지도 시간 >Spring Boot 구현 및 도메인 간 문제 해결을 위한 팁

Spring Boot 구현 및 도메인 간 문제 해결을 위한 팁

王林
王林원래의
2023-06-22 21:38:281824검색

프런트엔드와 백엔드 분리가 대중화되면서 프런트엔드와 백엔드 간의 도메인 간 문제가 점차 웹 개발자가 직면한 문제가 되었습니다. 교차 도메인 문제는 브라우저의 동일 출처 정책과 관련됩니다. 즉, 기본적으로 브라우저는 페이지가 동일한 출처의 서버에 대한 요청만 시작하도록 허용하고 다른 도메인 이름을 가진 서버에 대한 요청은 허용하지 않습니다. 이 기사에서는 Spring Boot 프레임워크를 사용하여 도메인 간 문제를 구현하고 해결하는 방법을 소개합니다.

  1. 도메인 간 문제란 무엇인가요?

교차 도메인 문제는 브라우저에서 도메인 이름 A로 실행되는 웹 애플리케이션이 도메인 이름 B의 웹 애플리케이션에 요청을 보낼 때 브라우저가 도메인 이름과 동일한 출처를 준수하지 않기 때문에 요청을 차단한다는 것을 의미합니다. 브라우저 정책 조항. 동일 출처 정책은 브라우저가 페이지의 프로토콜, 도메인 이름 및 포트 번호가 동일한 경우에만 페이지가 서버에 대한 요청을 시작하도록 허용한다는 것을 의미합니다.

  1. Spring Boot에서 지원되는 도메인 간 솔루션

Spring Boot는 도메인 간 문제를 해결하는 다양한 방법을 제공합니다. 다음은 보다 일반적인 방법 중 일부입니다.

2.1 @CrossOrigin 주석 사용

Spring Boot에서는 @CrossOrigin 주석을 사용하여 도메인 간 요청을 구현할 수 있습니다. @CrossOrigin 주석은 클래스 또는 메서드 수준에서 사용할 수 있으며 도메인 간 액세스가 허용되는 도메인 이름, 허용되는 요청 메서드 등과 같은 CORS에 대한 일부 옵션을 지정할 수 있습니다. 다음은 @CrossOrigin 주석을 사용한 샘플 코드입니다.

@RestController
@RequestMapping("/api")
@CrossOrigin(origins = "http://localhost:8080", maxAge = 3600)
public class ApiController {

    @GetMapping("/hello")
    public String hello() {
        return "Hello World!";
    }
}

위 코드에서는 @CrossOrigin 주석을 사용하고 크로스 도메인 도메인 이름은 http://localhost:8080으로 지정되며 최대 캐시 시간은 1시간으로 설정. 이러한 방식으로 프런트엔드 Ajax 요청을 할 때 도메인 전체에서 http://localhost:8080에 액세스할 수 있습니다. @CrossOrigin 주석은 @RequestBody 매개변수가 아닌 컨트롤러 클래스나 메서드에 추가되어야 한다는 점에 유의해야 합니다.

2.2 WebMvcConfigurer 구성

도메인 간 문제를 해결하는 또 다른 방법은 WebMvcConfigurer 인터페이스를 구현하고, addCorsMappings 메서드를 재정의하고, CorsRegistry를 사용하여 도메인 간 액세스를 허용하는 도메인 이름을 구성하는 것입니다. 다음은 샘플 코드입니다.

@Configuration
public class CorsConfig implements WebMvcConfigurer {

    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/api/**")
                .allowedOrigins("http://localhost:8080")
                .allowedMethods("GET", "POST")
                .maxAge(3600);
    }
}

위 코드에서 CorsConfig 클래스는 WebMvcConfigurer 인터페이스를 구현하고 addCorsMappings 메서드를 다루며 http://localhost:8080 도메인 이름에서 GET 및 POST 요청 액세스만 허용합니다. "/api"가 포함된 경로에는 CORS 제한이 적용되지만 다른 경로에는 제한이 없습니다.

2.3 필터 구성

필터를 사용하는 것도 도메인 간 문제를 해결하는 방법입니다. 다음은 필터 사용 예입니다.

@Component
public class CorsFilter implements Filter {

    @Override
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)
            throws ServletException, IOException {
        HttpServletResponse response = (HttpServletResponse) res;
        response.setHeader("Access-Control-Allow-Origin", "http://localhost:8080");
        response.setHeader("Access-Control-Allow-Methods", "GET, POST");
        response.setHeader("Access-Control-Max-Age", "3600");
        chain.doFilter(req, res);
    }
}

위 코드에서 CorsFilter 클래스는 Filter 인터페이스를 구현하고 Access-Control-Allow-Origin, Access-Control-Allow-Methods, Access-Control-Max-Age, 등. 헤더 정보를 요청하여 http://localhost:8080 도메인 이름에서 GET 및 POST 요청 액세스를 허용합니다.

  1. 요약

이 문서에서는 Spring Boot 프레임워크를 사용하여 도메인 간 문제를 구현하고 해결하는 세 가지 일반적인 방법을 소개합니다. CORS 제한 및 제어는 @CrossOrigin 주석을 사용하고 WebMvcConfigurer를 구성하고 필터를 사용하여 달성할 수 있습니다. 실제 개발에서는 필요에 따라 도메인 간 문제를 해결하는 데 가장 적합한 방법을 선택해야 합니다.

위 내용은 Spring Boot 구현 및 도메인 간 문제 해결을 위한 팁의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.