阅读量:109
要在Java的Jersey框架中实现跨域请求,你需要使用CORS(跨源资源共享)过滤器。以下是实现跨域请求的步骤:
- 首先,确保你已经添加了Jersey的CORS支持库。如果你使用的是Maven,可以在
pom.xml文件中添加以下依赖:
org.glassfish.jersey.containers.glassfish
jersey-gf-cdi
2.30.1
- 创建一个名为
CorsFilter的类,该类继承自ContainerResponseFilter接口。在这个类中,你需要重写filter方法,以便在响应头中添加CORS相关的信息。
import javax.ws.rs.container.ContainerRequestContext;
import javax.ws.rs.container.ContainerResponseContext;
import javax.ws.rs.container.ContainerResponseFilter;
import javax.ws.rs.core.MultivaluedMap;
import java.io.IOException;
public class CorsFilter implements ContainerResponseFilter {
@Override
public void filter(ContainerRequestContext requestContext, ContainerResponseContext responseContext) throws IOException {
MultivaluedMap headers = responseContext.getHeaders();
headers.add("Access-Control-Allow-Origin", "*");
headers.add("Access-Control-Allow-Methods", "GET, POST, DELETE, PUT, OPTIONS");
headers.add("Access-Control-Allow-Headers", "Content-Type, Authorization, Content-Length, X-Requested-With");
}
}
- 将
CorsFilter类注册到Jersey的应用程序配置中。你可以通过创建一个名为MyApplication的类来实现这一点,该类继承自ResourceConfig。
import org.glassfish.jersey.server.ResourceConfig;
public class MyApplication extends ResourceConfig {
public MyApplication() {
packages("com.example.yourpackage"); // 替换为你的包名
register(CorsFilter.class);
}
}
- 最后,确保你的Web服务器(如Tomcat、Jetty等)使用
MyApplication作为其配置类。这取决于你的部署方式和服务器类型。例如,如果你使用的是Tomcat,你需要在web.xml文件中添加以下内容:
Jersey Web Application
org.glassfish.jersey.servlet.ServletContainer
javax.ws.rs.Application
com.example.yourpackage.MyApplication <!-- 替换为你的包名 -->
1
现在,你的Jersey应用程序应该支持跨域请求。你可以根据需要调整CorsFilter类中的响应头,以便更精确地控制允许的源、方法和头。