Home > Java > javaTutorial > How to Implement CORS in JAX-RS Applications Using Jersey?

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

Susan Sarandon
Release: 2024-12-16 07:53:11
Original
290 people have browsed it

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

Dealing with CORS Using JAX-RS with Jersey

Introduction

Cross-Origin Resource Sharing (CORS) is a mechanism that enables cross-origin HTTP requests. It allows web applications to make requests to remote servers, even if the origins of the two servers are different. When implementing CORS, it is crucial to consider both simple and preflight requests.

Solution

To handle CORS in JAX-RS with Jersey, a ContainerResponseFilter can be employed. The following sections provide implementations for both Jersey 1.x and 2.x.

For 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");
    }
}
Copy after login

For 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;
    }
}
Copy after login

By implementing either of these filters, you can enable CORS support in your JAX-RS web application built using Jersey.

The above is the detailed content of How to Implement CORS in JAX-RS Applications Using Jersey?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template