rest - 带有 JAX-RS Jersey 2 和 Grizzly 的 Swagger 文档

标签 rest jax-rs swagger jersey-2.0 grizzly

我已经使用 JAX-RS 实现了一个 Rest web 服务(功能不相关)。现在我想使用 Swagger 生成它的文档。我已按照以下步骤操作:

1) 在 build.gradle 我得到了我需要的所有依赖:

编译'org.glassfish.jersey.media:jersey-media-moxy:2.13'

2) 我用 Swagger 注释记录我的代码

3) 我在我的 Application 子类中连接了 Swagger:

public class ApplicationConfig extends ResourceConfig  {

    /**
     * Main constructor
     * @param addressBook a provided address book
     */
    public ApplicationConfig(final AddressBook addressBook) {
        register(AddressBookService.class);
        register(MOXyJsonProvider.class);
        register(new AbstractBinder() {
            @Override
            protected void configure() {
                bind(addressBook).to(AddressBook.class);
            }
        });
        register(io.swagger.jaxrs.listing.ApiListingResource.class);
        register(io.swagger.jaxrs.listing.SwaggerSerializers.class);

        BeanConfig beanConfig = new BeanConfig();
        beanConfig.setVersion("1.0.2");
        beanConfig.setSchemes(new String[]{"http"});
        beanConfig.setHost("localhost:8282");
        beanConfig.setBasePath("/");
        beanConfig.setResourcePackage("rest.addressbook");
        beanConfig.setScan(true);
    }
}

但是,当我在 http://localhost:8282/swagger.json 中访问我的服务时,我得到了这个输出。

enter image description here

你可以查看我的公开 repo here .

最佳答案

在这种情况下(当对问题没有真正的解释时)我会抛出 ExceptionMapper<Throwable> .通常对于与服务器相关的异常,没有映射器来处理异常,因此它会冒泡到容器中,我们会收到一个无用的 500 状态代码,可能还有一些来自服务器的无用消息(正如您从 Grizzly 看到的那样)。

import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.Response;
import javax.ws.rs.ext.ExceptionMapper;

public class DebugMapper implements ExceptionMapper<Throwable>  {

    @Override
    public Response toResponse(Throwable exception) {
        exception.printStackTrace();
        if (exception instanceof WebApplicationException) {
            return ((WebApplicationException)exception).getResponse();
        }
        return Response.serverError().entity(exception.getMessage()).build();
    }  
}

然后只需注册应用程序

public ApplicationConfig(final AddressBook addressBook) {
    ...
    register(DebugMapper.class);
}

当您再次运行应用程序并尝试访问端点时,您现在将看到一个堆栈跟踪,其中包含异常原因

java.lang.NullPointerException
  at io.swagger.jaxrs.listing.ApiListingResource.getListingJson(ApiListingResource.java:90)

如果您查看 source code对于 ApiListingResource.java:90 ,你会看到

Swagger swagger = (Swagger) context.getAttribute("swagger");

这里唯一可能导致 NPE 的是 context , 其中 scrolling up会告诉你它是ServletContext .现在这是它为空的原因。为了让那里甚至成为一个ServletContext ,应用程序需要在 Servlet 环境中运行。但是看看你的设置:

HttpServer server = GrizzlyHttpServerFactory
        .createHttpServer(uri, new ApplicationConfig(ab));

这不会创建 Servlet 容器。它只创建一个 HTTP 服务器。您拥有创建 Servlet 容器 (jersey-container-grizzly2-servlet) 所需的依赖项,但您只需要使用它即可。因此,您应该这样做,而不是以前的配置,

ServletContainer sc = new ServletContainer(new ApplicationConfig(ab));
HttpServer server = GrizzlyWebContainerFactory.create(uri, sc, null, null); 
// you will need to catch IOException or add a throws clause

查看 GrizzlyWebContainerFactory 的 API其他配置选项。

现在,如果您运行它并再次点击端点,您将看到 Swagger JSON。请注意,来自端点的响应只是 JSON,而不是文档接口(interface)。为此,您需要使用可以解释 JSON 的 Swagger UI。

感谢 MCVE顺便说一句。

关于rest - 带有 JAX-RS Jersey 2 和 Grizzly 的 Swagger 文档,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33681371/

相关文章:

javascript - 从 SalesForce 查询图像作为 blob

amazon-web-services - 通过 terraform 部署的 AWS API Gateway 和 Lambda 函数 -- 由于配置错误 : Invalid permissions on Lambda function 导致执行失败

api - 使用 Swagger 和 ServiceStack 记录响应类

objective-c - GTMOAuth 的 FatSecret REST KIT 问题

Java:内部类传值的线程安全

java - AsyncInvoker 不释放线程

java - 在 Spring Boot 应用程序中通过 Jersey 资源方法提供静态内容

Django Rest 框架 swagger 基本 url

rest - 当不支持 HTTP 方法时向客户端发送消息

glassfish - Glassfish 3.0.1 : Can I have an empty webapp element in my web. xml 上的 Jersey JAX-RS?