【问题标题】:Springfox Swagger Configuration and Documentation not being captured未捕获 Springfox Swagger 配置和文档
【发布时间】:2017-06-24 01:20:31
【问题描述】:

这是我第一次来这里。所以我们有一个在 Spring MVC 中构建的应用程序,它使用 2 个 Java 类作为控制器来处理 REST 调用。其中一个用@Controller 显式注释,而另一个用@Component 注释。 (定义路线的两种方式略有不同)

我们面临的问题是,尽管我们进行了配置/设置,但我们只看到一个没有端点和文档填写的空 UI。它基本上是一个空白画布。我们进行了大量搜索,尽管尝试了 bean 和定义的多种配置,但我们仍然遇到了同样的问题。

最近我们尝试了这个例子:Swagger Springfox Configuration Issue

我们的设置/配置和相关文件的一些 sn-ps 在下面生成。

控制器类:

用户设备认证控制器

@RestController
public class UserDeviceAuthenticationController {

private static final Logger LOGGER = Logger
        .getLogger(UserDeviceAuthenticationController.class);

/**
 * 
 * @param response
 * @param request
 * @param deviceID: a misnomer. This field is different for every client set up on Fitbit
 * @throws IOException
 * @throws ParseException
 */
@RequestMapping(value = "/fitbitEndPoint", method = RequestMethod.POST)
public void fitbitEndPoint(HttpServletResponse response,
      //Body logic redacted

}

PHDDeviceRestService

@Path("device/v2.0")
@Component
public class PHDDeviceRestService extends BaseServiceImpl {

    @POST
    @Path("/{deviceId}/url")
    @Produces({ MediaType.APPLICATION_JSON })
    @Consumes({ MediaType.APPLICATION_JSON })
    public Response getDeviceURL(GetDeviceURLRequest getDeviceURLRequest, @PathParam("deviceId") Long deviceId) throws PHDWebServiceException {
         //Logic redacted
    }

配置文件:

我们在 Pom.xml 中的相关 Swagger Springfox 依赖项

<!-- Swagger dependency -->
<dependencies>
   <dependency>
      <groupId>io.springfox</groupId>
      <artifactId>springfox-swagger2</artifactId>
      <version>2.6.0</version>
   </dependency>
   <dependency>
      <groupId>io.springfox</groupId>
      <artifactId>springfox-swagger-ui</artifactId>
      <version>2.6.0</version>
   </dependency>
</dependencies>

我们的 web.xml 包含 servlet 和 url 模式:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" version="2.5">

<servlet>
  <servlet-name>Spring MVC Dispatcher Servlet</servlet-name>
  <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  <init-param>
     <param-name>contextConfigLocation</param-name>
     <param-value>/WEB-INF/mvc/webmvc-config.xml</param-value>
  </init-param>
  <load-on-startup>1</load-on-startup>
</servlet>
<!-- Map all *.spring requests to the DispatcherServlet for handling -->
<servlet-mapping>
  <servlet-name>Spring MVC Dispatcher Servlet</servlet-name>
  <url-pattern>/devices/*</url-pattern>
</servlet-mapping>
<servlet-mapping>
  <servlet-name>Spring MVC Dispatcher Servlet</servlet-name>
  <url-pattern>/healthyweight/*</url-pattern>
</servlet-mapping>
<servlet-mapping>
  <servlet-name>Spring MVC Dispatcher Servlet</servlet-name>
  <url-pattern>/DevicesGateway/*</url-pattern>
</servlet-mapping>
<servlet>
  <servlet-name>jersey</servlet-name>
  <servlet-class>com.sun.jersey.spi.spring.container.servlet.SpringServlet</servlet-class>
  <init-param>
     <param-name>com.sun.jersey.config.property.packages</param-name>
     <param-value>com.uhg.phd.rest;com.uhg.phd.rest.MongoDB</param-value>
  </init-param>
  <load-on-startup>1</load-on-startup>
</servlet>
<servlet>
  <servlet-name>CXFSevlet</servlet-name>
  <servlet-class>org.apache.cxf.transport.servlet.CXFServlet</servlet-class>
  <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
    <servlet-name>CXFSevlet</servlet-name>
    <url-pattern>/services/*</url-pattern>
</servlet-mapping>
<servlet-mapping>
    <servlet-name>CXFSevlet</servlet-name>
    <url-pattern>/ws/*</url-pattern>
</servlet-mapping>
<!-- <servlet-mapping>
    <servlet-name>Spring MVC Dispatcher Servlet</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping> -->
<servlet-mapping>
    <servlet-name>CXFSevlet</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping>
<!-- <servlet-mapping>
   <servlet-name>Spring MVC Dispatcher Servlet</servlet-name>
   <url-pattern>/swagger-ui.html</url-pattern>
</servlet-mapping> -->
</web-app>

定义 Docket Bean 的 SwaggerConfig 类:

@EnableSwagger2
public class SwaggerConfig {

@Bean
public Docket api() {
    return new Docket(DocumentationType.SWAGGER_2)
            .select()
            .apis(RequestHandlerSelectors.any())
            .paths(PathSelectors.any())
            .build();
}

}

我们的带有 ViewControllers 和 ResourceHandlers 的 WebMvcConfig 类:

@EnableWebMvc
public class WebMvcConfig extends WebMvcConfigurerAdapter {

@Override
public void addViewControllers(ViewControllerRegistry registry) {
    registry.addRedirectViewController("/documentation/v2/api-docs", "/v2/api-docs?group=restful-api");
    registry.addRedirectViewController("/documentation/swagger-resources/configuration/ui","/swagger-resources/configuration/ui");
    registry.addRedirectViewController("/documentation/swagger-resources/configuration/security","/swagger-resources/configuration/security");
    registry.addRedirectViewController("/documentation/swagger-resources", "/swagger-resources");
}

@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
    registry.addResourceHandler("documentation/swagger-ui.html")
    .addResourceLocations("classpath:/META-INF/resources/");

    registry.addResourceHandler("documentation/webjars/**")
    .addResourceLocations("classpath:/META-INF/resources/webjars/");
}

}

感谢您阅读所有这些内容。如果您想查看我们的代码/文件或者我是否遗漏了任何内容,请告诉我。任何意见表示赞赏!

【问题讨论】:

    标签: java spring-mvc tomcat7 swagger-ui swagger-2.0


    【解决方案1】:

    您可能已经找到了答案,但如果有人遇到同样的问题,也许这对他们有帮助:

    对我来说,诀窍是将包含我的SwaggerConfig 的包添加到ComponentScan basePackages 的列表中。基本上我有相同的SwaggerConfig,但我的Application 文件(我正在使用Spring boot)看起来像这样:

    @Configuration
    @EnableAutoConfiguration
    @ComponentScan(basePackages = {
            "my.test.config",
            "my.test.controllers",
            "my.test.models"})
    public class SwaggerTestApplication {
    
        public static void main(String[] args) {
            ConfigurableApplicationContext context = SpringApplication.run(SwaggerTestApplication.class, args);
        }
    }
    

    重要的部分是 ComponentScan 中的 "my.test.config" 包 - 其中定义了 SwaggerConfig

    【讨论】:

    • 你好都铎王朝。谢谢你的建议。我们在 Spring MVC 中,而不是 Spring boot。无论如何,我们定义了一个指向 webmvc-config.xml 和 applicationContext.xml 文件的 web.xml 文件。在这些文件中,“”已被设置和定义。基本包包含所有类和 java 文件,包括我已经定义 SwaggerConfig 的位置。例如,SwaggerConfig 文件属于 com.uhg.phd.Configuration 并且应该已经被包含地扫描。 XML 是不是不如直接在 Java 中直接定义它们健壮?
    • xml 与在 Java 中定义它们一样健壮 - 所以这不是问题。如果您还没有,您可能需要查看官方存储库中的示例:github.com/springfox/springfox-demos/tree/master/… 并确保找到您的 SwaggerConfig(来自示例): ...这就是我现在能想到的。
    猜你喜欢
    • 2016-11-25
    • 2020-03-27
    • 1970-01-01
    • 2017-11-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-07-27
    • 2019-04-14
    相关资源
    最近更新 更多