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 중국어 웹사이트의 기타 관련 기사를 참조하세요!