JAX-RS 및 Jersey(1.x 및 2.x)를 사용하여 CORS 필터링을 구현하는 방법은 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











2025 년 상위 4 개의 JavaScript 프레임 워크 : React, Angular, Vue, Svelte

카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?

Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?

Spring Boot Snakeyaml 2.0 CVE-2022-1471 문제 고정

캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?

고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?
