java - 使用 Swagger 的 Jersey Rest API 文档

标签 java rest maven swagger jersey-1.0

我正在尝试使用 Swagger 在 API 文档中查看我的 Jersey 休息服务方法列表。浏览了 GitHub 站点中给出的一些示例/样本。但当我尝试访问上下文根链接时,我仍然无法列出我的服务方法。未找到获取 404 服务。

pom.xml:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.danfoss.des</groupId>
<artifactId>SampleRestProject</artifactId>
<packaging>war</packaging>
<version>0.0.1-SNAPSHOT</version>
<name>SampleRestProject Maven Webapp</name>
<url>http://maven.apache.org</url>
<dependencies>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>3.8.1</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>com.sun.jersey</groupId>
        <artifactId>jersey-server</artifactId>
        <version>1.9</version>
    </dependency>
    <dependency>
        <groupId>com.sun.jersey</groupId>
        <artifactId>jersey-client</artifactId>
        <version>1.9</version>
    </dependency>
    <dependency>
        <groupId>com.sun.jersey</groupId>
        <artifactId>jersey-json</artifactId>
        <version>1.9</version>
    </dependency>
    <dependency>
        <groupId>io.swagger</groupId>
        <artifactId>swagger-jersey-jaxrs</artifactId>
        <version>1.5.0</version>
    </dependency>
    <!-- <dependency>
        <groupId>com.wordnik</groupId>
        <artifactId>swagger-jaxrs_2.9.1</artifactId>
        <version>1.2.0</version>
        <scope>compile</scope>
    </dependency> -->
</dependencies>
<build>
    <finalName>SampleRestProject</finalName>
</build>

web.xml

<!DOCTYPE web-app PUBLIC
 "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
 "http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
  <display-name>Archetype Created Web Application</display-name>

  <servlet>
        <servlet-name>helloworld</servlet-name>
        <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class>
        <init-param>
            <param-name>com.sun.jersey.config.property.packages</param-name>
            <param-value>io.swagger.jaxrs.listing,com.danfoss.des</param-value>
        </init-param>
        <init-param>
            <param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name>
            <param-value>true</param-value>
        </init-param>
        <!-- <init-param>
            <param-name>api.version</param-name>
            <param-value>1.0.0</param-value>
        </init-param>
        <init-param>
            <param-name>swagger.api.basepath</param-name>
            <param-value>http://localhost:8081/SampleRestProject/</param-value>
        </init-param> -->
        <load-on-startup>1</load-on-startup>
    </servlet>
     <servlet>
        <servlet-name>JerseyJaxrsConfig</servlet-name>
        <servlet-class>io.swagger.jersey.config.JerseyJaxrsConfig</servlet-class>
        <init-param>
            <param-name>api.version</param-name>
            <param-value>1.0</param-value>
        </init-param>
        <init-param>
            <param-name>swagger.api.basepath</param-name>
            <param-value>http://localhost:8081/SampleRestProject/rest</param-value>
        </init-param>
        <load-on-startup>2</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>helloworld</servlet-name>
        <url-pattern>/rest/*</url-pattern>
    </servlet-mapping>
    <!-- <welcome-file-list>
        <welcome-file>index.html</welcome-file>
    </welcome-file-list> -->

</web-app>

服务java类:

package com.danfoss.des;

import javax.ws.rs.Consumes;
import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;

import com.danfoss.model.Track;

import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;


@Path("/helloWorld")
@Api(value="helloWorld", description="Sample hello world swagger service")
public class RESTfulHelloWorld 
{
    @GET
    @Produces("text/html")
    @Path("/startingPage")
    @ApiOperation(value="Starting of the swagger service")
    public Response getStartingPage()
    {
        String output = "Staring method is invoked";
        return Response.status(200).entity(output).build();
    }
}

My Project structure

正在尝试访问查看列表的链接:http://localhost:8081/SampleRestProject/api-docs

有人可以帮我找出到底哪里出了问题或者我是否遗漏了任何东西。

最佳答案

JerseyJaxrsConfig类是 swagger-jersey2-jaxrs 的一部分库,因此在部署 web 应用程序时不可用,因为您正在使用 swagger-jersey-jaxrs与 Jersey 1.9 结合(很好)。

简单地替换

<servlet-class>io.swagger.jaxrs.config.JerseyJaxrsConfig</servlet-class>

<servlet-class>io.swagger.jaxrs.config.DefaultJaxrsConfig</servlet-class>

使用正确的配置类,然后尝试访问 http://localhost:8081/SampleRestProject/rest/swagger.json再次。

此外,在进行此操作时,请考虑将 Swagger 的基本路径定义为相对路径,以便您能够将 Web 应用程序部署在不同的端口上。

<init-param>
    <param-name>swagger.api.basepath</param-name>
    <param-value>/SampleRestProject/rest</param-value>
</init-param>

关于java - 使用 Swagger 的 Jersey Rest API 文档,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44105508/

相关文章:

java - 字符串数组不反向输出

java - 获取声明枚举的类

java - 使用 Jersey 2.13 时出现 ClientAbortException

javascript - 在 Sails.JS 中获取上传图像的下载 url

maven - 如何从 Liferay 7 取消部署 portlet?

java - 如何使用 Maven 部署多项目?

java - 线程 "main"中的异常 java.io.IOException : Cannot run program "D:/cygwin/bin/bash": CreateProcess error=193, %1 不是有效的 Win32 应用程序

java - 当列为空时,如何使用 BaseAdapter 动态删除一行表?

java - Spring Boot - 不允许使用 POST 方法

java - 使用 Jetty 和 Maven 上传文件