JAX-RS异常映射器无法在Grizzly容器中运行

时间:2016-06-29 11:35:13

标签: exception-handling jax-rs jersey-2.0 grizzly exceptionmapper

与团队合作开发Jersey Web应用程序,随着项目变得越来越大,我们决定从Tomcat切换到Grizzly,以允许在不同的端口号上部署项目的一部分。我现在发现,我们现在无法使用自定义异常处理,而是总是得到灰熊的html页面。

示例异常:

public class DataNotFoundException extends RuntimeException{

private static final long serialVersionUID = -1622261264080480479L;

public DataNotFoundException(String message) {
    super(message);
    System.out.println("exception constructor called"); //this prints
 }
}

映射器:

@Provider
public class DataNotFoundExceptionMapper implements ExceptionMapper<DataNotFoundException>{

public DataNotFoundExceptionMapper() {
    System.out.println("mapper constructor called"); //doesnt print
}

@Override
public Response toResponse(DataNotFoundException ex) {
    System.out.println("toResponse called"); //doesnt print
    ErrorMessage errorMessage = new ErrorMessage(ex.getMessage(), 404, "No documentation yet."); 
    return Response.status(Status.NOT_FOUND)
            .entity(errorMessage)
            .build();
      //ErrorMessage is a simple POJO with 2 string and 1 int field
 }

}

我不确定问题来源在哪里,如果需要,我可以提供更多信息/代码。问题是什么,我该怎么办?

编辑

Main.class:

public class Main {

/**
 * Main method.
 * @param args
 * @throws Exception 
 */
public static void main(String[] args) throws Exception {

...

    List<ServerInfo> serverList = new ArrayList<ServerInfo>();

    serverList.add(new ServerInfo(
            "api",8450,
            new ResourceConfig().registerClasses(
                    the.package.was.here.ApiResource.class)
            ));             

    for(ServerInfo server : serverList) {
        server.start();
    }

    System.out.println("Press enter to exit...");
    System.in.read();

    for(ServerInfo server : serverList) {
        server.stop();
    }

}
}

EDIT2: 根据{{​​3}}问题,我尝试使用此ServerProperties.RESPONSE_SET_STATUS_OVER_SEND_ERROR, "true"属性,这只会有所帮助。当异常发生时我仍然得到html灰熊页面,但现在我在页面正文中看到了我的异常(+堆栈跟踪)。

1 个答案:

答案 0 :(得分:3)

您只为整个应用程序注册一个资源类

new ResourceConfig().registerClasses(
        eu.arrowhead.core.api.ApiResource.class
)

映射器也需要注册

new ResourceConfig().registerClasses(
        eu.arrowhead.core.api.ApiResource.class,
        YourMapper.class)
)

您还可以使用包扫描,如果使用@Path@Provider

注释,它将获取所有类并自动注册它们
new ResourceConfig().packages("the.packages.to.scan")