我有一个ExceptionMapper
作为@Provider
用于处理我的所有异常。
所以很明显我的类实现了 ExceptionMapper<Throwable>
众所周知,所有异常(exception)情况均已延长 Throwable
不知怎的。
现在我使用jax-rs @NotNull
检查我的资源输入值不为空,通过一些搜索,我意识到它会抛出 ConstraintViolationException
当注释字段为空时。
所以我尝试处理它并在我的 ExceptionMapper 中添加一些响应详细信息(添加一些自定义 json 模型),如下所示:
@Provider
public class AllExceptionMapper implements ExceptionMapper<Throwable> {
private final Logger logger = LogManager.getLogger(AllExceptionMapper.class);
@Override
public Response toResponse(Throwable ex) {
Response response;
CustomError error;
// handle some errors
else if (ex instanceof ConstraintViolationException) {
error = new CustomError(
324, // predefined error type in our documents
"some details"
);
response = Response.status(Response.Status.BAD_REQUEST).entity(error).build();
}
// handle some other errors
return response;
}
}
问题是这不起作用但是如果我创建另一个实现 ExceptionMapper<ConstraintViolationException>
的异常映射器提供程序并在那里处理它,它工作没有任何问题。
正如我之前所说(并且也检查过),所有异常都从 Throwable
扩展而来。不知怎的,我错过了什么以及为什么它不起作用?
……
通过不起作用,我的意思是它忽略我的映射器(从 ExceptionMapper<Throwable>
实现的映射器)并具有正常行为,即返回状态代码 400 且没有响应负载,就像根本没有映射器一样
最佳答案
方式ExceptionMapper
应该可以工作,你可以创建一个通用的 ExceptionMapper<Throwable>
,它处理所有错误。然后您可以创建更具体的ExceptionMapper
以另一种方式处理更具体的错误。所有这些都在不同的类(class)中进行。
事实上,在一个单独的类中完成它对你来说是有效的,让我相信有一个更具体的 ExceptionMapper
某个地方,它会先于你处理异常。
ExceptionMappers 的使用方式实际上非常干净,并且还能保持代码干净。想要将代码保留在一个中心位置,将导致一个巨大的 if
...
关于java - JAX-RS( Jersey 实现)ExceptionMapper<Throwable> 未捕获 ConstraintViolationException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53063143/