要在Java的Jersey框架中实现跨域请求,你需要使用CORS(跨源资源共享)过滤器。以下是实现跨域请求的步骤:
pom.xml
文件中添加以下依赖: <groupId>org.glassfish.jersey.containers.glassfish</groupId>
<artifactId>jersey-gf-cdi</artifactId>
<version>2.30.1</version>
</dependency>
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<String, Object> 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);
}
}
MyApplication
作为其配置类。这取决于你的部署方式和服务器类型。例如,如果你使用的是Tomcat,你需要在web.xml
文件中添加以下内容: <servlet-name>Jersey Web Application</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>javax.ws.rs.Application</param-name>
<param-value>com.example.yourpackage.MyApplication</param-value> <!-- 替换为你的包名 -->
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
现在,你的Jersey应用程序应该支持跨域请求。你可以根据需要调整CorsFilter
类中的响应头,以便更精确地控制允许的源、方法和头。