> Java > java지도 시간 > Jersey를 사용하여 JAX-RS 애플리케이션에서 CORS를 구현하는 방법은 무엇입니까?

Jersey를 사용하여 JAX-RS 애플리케이션에서 CORS를 구현하는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2024-12-16 07:53:11
원래의
290명이 탐색했습니다.

How to Implement CORS in JAX-RS Applications Using Jersey?

저지와 함께 JAX-RS를 사용하여 CORS 처리

소개

교차 원본 리소스 CORS(공유)는 원본 간 HTTP 요청을 활성화하는 메커니즘입니다. 두 서버의 원본이 다른 경우에도 웹 응용 프로그램이 원격 서버에 요청할 수 있습니다. CORS를 구현할 때 단순 요청과 실행 전 요청을 모두 고려하는 것이 중요합니다.

솔루션

Jersey를 사용하는 JAX-RS에서 CORS를 처리하려면 ContainerResponseFilter를 사용할 수 있습니다. 다음 섹션에서는 Jersey 1.x 및 2.x 모두에 대한 구현을 제공합니다.

Jersey 2.x의 경우:

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

@Provider
public class CORSFilter implements ContainerResponseFilter {

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

Jersey 1의 경우. x:

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

@Provider
public class CORSFilter implements ContainerResponseFilter {

    @Override
    public ContainerResponse filter(ContainerRequest requestContext, ContainerResponse responseContext) {
        responseContext.getHttpHeaders().add("Access-Control-Allow-Origin", "*");
        responseContext.getHttpHeaders().add("Access-Control-Allow-Headers", "CSRF-Token, X-Requested-By, Authorization, Content-Type");
        responseContext.getHttpHeaders().add("Access-Control-Allow-Credentials", "true");
        responseContext.getHttpHeaders().add("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS, HEAD");
        return responseContext;
    }
}
로그인 후 복사

이러한 필터 중 하나를 구현하면 다음을 활성화할 수 있습니다. Jersey를 사용하여 구축된 JAX-RS 웹 애플리케이션에서 CORS를 지원합니다.

위 내용은 Jersey를 사용하여 JAX-RS 애플리케이션에서 CORS를 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿