【发布时间】:2026-01-18 23:10:01
【问题描述】:
我正在使用 JBoss 6.4 EAP 和 Resteasy 2.3.10 Final 和 jaxrs api spec 1.1(容器中已经提供了所有这些库)。
我想念 ContainerResponseFilter,因为它包含在 jaxrs 2.0 规范中,因此这个 SO question 在我的情况下不起作用。 我可以使用哪种方法来启用 CORS?
【问题讨论】:
我正在使用 JBoss 6.4 EAP 和 Resteasy 2.3.10 Final 和 jaxrs api spec 1.1(容器中已经提供了所有这些库)。
我想念 ContainerResponseFilter,因为它包含在 jaxrs 2.0 规范中,因此这个 SO question 在我的情况下不起作用。 我可以使用哪种方法来启用 CORS?
【问题讨论】:
我必须以这种方式实现标准 javax.servlet.Filter:
package javax.servlet;
import java.io.IOException;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletResponse;
@WebFilter(urlPatterns="/*")
public class ApiOriginFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
HttpServletResponse res = (HttpServletResponse) response;
res.addHeader("Access-Control-Allow-Origin", "*");
res.addHeader("Access-Control-Allow-Methods", "GET, POST, DELETE, PUT");
res.addHeader("Access-Control-Allow-Headers", "Content-Type, api_key, Authorization");
chain.doFilter(request, response);
}
@Override
public void destroy() {
}
}
【讨论】: