我有一个Java thorntail应用程序,我想在其中捕获所有未捕获的异常。
我想用500而不是JAXRS给出的默认错误页面进行响应,所以我只使用了ExceptionMapper<Throwable>
的实现。
使用Postman进行测试没有问题,但是一旦我尝试在浏览器中进行AJAX调用,我最终就发送了OPTIONS请求,但失败了。
还可以通过实现ContainerResponseFilter
在应用程序一侧实现CORS部分。
我觉得匹配是在请求的早期发生的,直到后来CORSFilter才对响应产生影响。
我已经尝试过的几件事:
@预匹配
@优先
尝试导入jboss.resteasy CorsFilter
试图通过exception instanceof DefaultOptionsMethodException
过滤掉异常,但最终弄清DefaultOptionsMethodException
不在类路径中,并且它是内部(?)软件包,包含在thorntails类路径(??)中
...
// CORSFilter
package com.testapplication.test.rest;
import java.io.IOException;
import javax.ws.rs.container.ContainerRequestContext;
import javax.ws.rs.container.ContainerResponseContext;
import javax.ws.rs.container.ContainerResponseFilter;
import javax.ws.rs.ext.Provider;
@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-Methods", "GET, POST, PUT, DELETE, OPTIONS");
responseContext.getHeaders().add("Access-Control-Max-Age", "-1");
responseContext.getHeaders().add("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
}
}
// UncaughtExceptionMapper
package com.testapplication.test.rest;
import javax.ws.rs.core.Response;
import javax.ws.rs.ext.ExceptionMapper;
import javax.ws.rs.ext.Provider;
@Provider
public class UncaughtExceptionMapper extends Throwable implements ExceptionMapper<Throwable> {
@Override
public Response toResponse(Throwable exception) {
exception.printStackTrace();
return Response.status(500).entity("{\"message\": \"a\"}").build();
}
}
示例存储库:https://github.com/trimpirim/cors-filter-conflict-exception-mapper
最佳答案
尝试使用this post底部的过滤器。就CORS交互而言,仅使用响应过滤器将无法正确执行。您还需要一个请求过滤器来中止对预检请求的请求。