>Java >java지도 시간 >JAX-RS 및 Jersey(1.x 및 2.x)를 사용하여 CORS 필터링을 구현하는 방법은 무엇입니까?

JAX-RS 및 Jersey(1.x 및 2.x)를 사용하여 CORS 필터링을 구현하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-17 04:09:24808검색

How to Implement CORS Filtering with JAX-RS and Jersey (1.x and 2.x)?

JAX-RS 및 Jersey로 CORS 처리

CORS(Cross-Origin Resource Sharing)를 사용하면 서로 다른 도메인의 리소스 간에 안전한 데이터 교환이 가능합니다. Jersey와 함께 JAX-RS를 사용하여 Java 애플리케이션에서 CORS를 처리하려면 ContainerResponseFilter를 활용할 수 있습니다. 이 기사에서는 Jersey 2.x 및 1.x 버전 모두에서 CORS 필터링을 구현하는 방법을 살펴보겠습니다.

Jersey 2.x

Jersey 2의 경우. x에서는 다음과 같은 ContainerResponseFilter 구현이 우리의 목적에 부합합니다. 효과적으로:

import java.io.IOException;
import javax.ws.rs.container.ContainerRequestContext;
import javax.ws.rs.container.ContainerResponseContext;
import javax.ws.rs.container.ContainerResponseFilter;

@Provider
public class CORSFilter implements ContainerResponseFilter {

    @Override
    public void filter(ContainerRequestContext request, ContainerResponseContext response) throws IOException {
        response.getHeaders().add("Access-Control-Allow-Origin", "*");
        response.getHeaders().add("Access-Control-Allow-Headers", "CSRF-Token, X-Requested-By, Authorization, Content-Type");
        response.getHeaders().add("Access-Control-Allow-Credentials", "true");
        response.getHeaders().add("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS, HEAD");
    }
}

Jersey 1.x

Jersey 1.x의 경우 다음과 같은 ContainerResponseFilter 구현을 사용해야 합니다.

import com.sun.jersey.spi.container.ContainerRequest;
import com.sun.jersey.spi.container.ContainerResponse;
import com.sun.jersey.spi.container.ContainerResponseFilter;

@Provider
public class CORSFilter implements ContainerResponseFilter {
    @Override
    public ContainerResponse filter(ContainerRequest request, ContainerResponse response) {

        response.getHttpHeaders().add("Access-Control-Allow-Origin", "*");
        response.getHttpHeaders().add("Access-Control-Allow-Headers", "CSRF-Token, X-Requested-By, Authorization, Content-Type");
        response.getHttpHeaders().add("Access-Control-Allow-Credentials", "true");
        response.getHttpHeaders().add("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS, HEAD");

        return response;
    }
}

구성 중 필터

애플리케이션에 이러한 필터를 등록하려면 패키지 검색이나 명시적 등록을 사용할 수 있습니다. Jersey 2.x의 경우 패키지 스캔으로 충분하지만 Jersey 1.x의 경우 web.xml 또는 ResourceConfig에 명시적인 등록이 필요할 수 있습니다.

추가 고려 사항

제발 이 구현은 단순한 접근 방식이며 모든 CORS 관련 세부 사항을 다루지 않을 수도 있습니다. 보다 강력하고 사용자 정의 가능한 솔루션을 위해서는 최신 CORS 사양을 준수하는 RESTeasy에서 제공하는 CorsFilter를 살펴보는 것이 좋습니다.

위 내용은 JAX-RS 및 Jersey(1.x 및 2.x)를 사용하여 CORS 필터링을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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