首页 文章

Resteasy ExceptionMapper没有返回任何结果

提问于
浏览
0

我正在为EJB服务开发REST-facade,这意味着它调用EJB,将结果转换为REST调用者将理解的表示,然后将其返回(如json或xml) . 所有这些都很棒 . 但EJB服务引发了各种异常,例如: G . 当没有找到结果或几个不同的其他情况 . 由于我不希望那些传播到REST调用者,我实现了一个ExceptionMapper:

public class EjbExceptionMapper implements ExceptionMapper<EJBException> {

    private static final Logger logger = LoggerFactory.getLogger(EjbExceptionMapper.class);

    @Override
    public Response toResponse(final EJBException exception) {
        ResponseBuilder result = Response.status(Status.BAD_REQUEST);
        logger.debug("Bad request:", exception);
        if (exception.getCause() != null) {
            final Throwable cause = exception.getCause();
            if (cause instanceof NoDeliveryFoundException) {
                logger.debug("Found NoDeliveryFoundException:", cause);
                result = Response.status(Status.NO_CONTENT).entity(cause.getMessage());
            }
        }
        return result.build();
    }
}

我的EJB服务的所有异常都以 javax.ejb.EJBException 形式到达,这个Mapper可以很好地捕获,并将应用程序的不同自定义异常作为原因 . 计划是根据EJBException的原因类型返回不同的响应 . 用于调试的 Logger 调用都是在我得到NoDeliveryFoundException作为原因的情况下执行的,因此我知道它已执行(Mapper正确注册并用于映射),但客户端从未看到响应 .

在底层服务中导致EJBException的每次调用(以及因此使用此ExceptionMapper)都不会导致响应,就好像toResponse() - 方法返回null而不是自定义构建的Response .

我甚至在返回之前记录了响应,它存在并包含我期望的内容,所以我很肯定它是由toResponse方法返回的 . 但是,我的客户仍然没有收到回应 .

所以现在我很难过,因为没有搜索设法甚至找不到描述类似问题的人,所以我转向你,亲爱的 . ;)

1 回答

  • 2

    你的 toResponse -method包含一些冲突的逻辑 .

    Response.status(Status.NO_CONTENT).entity(cause.getMessage());

    您在此处分配HTTP状态代码 204 No Content ,但您还要添加响应 . 您无法将状态设置为 204 No Content 并同时返回响应正文 .

    此外,如果 Exception#getCause() 为null或者它不是 NoDeliveryFoundException 的实例,则响应正文为空 .

    这可能是你问题的原因吗?

相关问题