我的pom.xml
<!-- Swagger io for API doc -->
<dependency>
<groupId>io.swagger</groupId>
<artifactId>swagger-core</artifactId>
<version>1.5.3</version>
<exclusions>
<exclusion>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
</exclusion>
<exclusion>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
</exclusion>
<exclusion>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.6.1</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.6.1</version>
</dependency>
Swagger配置
@Configuration
@EnableWebMvc
@EnableSwagger2
public class SwaggerConfig {
@Bean
public Docket api() {
return new Docket(DocumentationType.SWAGGER_2)
.select()
.apis(RequestHandlerSelectors.any())
.paths(PathSelectors.any())
.build()
.apiInfo(apiInfo());
}
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title("allocation-order-service")
.description("domain services having persistance layer")
.version("1.0")
.build();
}
}
服务器日志
16-05-18 13:08:59.137 ContainerBackgroundProcessor[StandardEngine[Catalina]] INFO o.s.w.s.m.m.a.RequestMappingHandlerMapping registerHandlerMethod 190 Mapped "{[/${springfox.documentation.swagger.v2.path:/v2/api-docs}],methods=[GET],params=[],headers=[],consumes=[],produces=[application/json || application/hal+json],custom=[]}" onto public org.springframework.http.ResponseEntity<springfox.documentation.spring.web.json.Json> springfox.documentation.swagger2.web.Swagger2Controller.getDocumentation(java.lang.String,javax.servlet.http.HttpServletRequest)
16-05-18 13:08:59.141 ContainerBackgroundProcessor[StandardEngine[Catalina]] INFO o.s.w.s.m.m.a.RequestMappingHandlerMapping registerHandlerMethod 190 Mapped "{[/swagger-resources/configuration/security],methods=[],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto org.springframework.http.ResponseEntity<springfox.documentation.swagger.web.SecurityConfiguration> springfox.documentation.swagger.web.ApiResourceController.securityConfiguration()
16-05-18 13:08:59.143 ContainerBackgroundProcessor[StandardEngine[Catalina]] INFO o.s.w.s.m.m.a.RequestMappingHandlerMapping registerHandlerMethod 190 Mapped "{[/swagger-resources/configuration/ui],methods=[],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto org.springframework.http.ResponseEntity<springfox.documentation.swagger.web.UiConfiguration> springfox.documentation.swagger.web.ApiResourceController.uiConfiguration()
16-05-18 13:08:59.145 ContainerBackgroundProcessor[StandardEngine[Catalina]] INFO o.s.w.s.m.m.a.RequestMappingHandlerMapping registerHandlerMethod 190 Mapped "{[/swagger-resources],methods=[],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto org.springframework.http.ResponseEntity<java.util.List<springfox.documentation.swagger.web.SwaggerResource>> springfox.documentation.swagger.web.ApiResourceController.swaggerResources()
它说Mapped:/${springfox.documentation.swagger.v2.path:/v2/api-docs}
但这些都不起作用(404):
http://localhost:8080/allocation-order-web/v2/api-docs
http://localhost:8080/allocation-order-web/${springfox.documentation.swagger.v2.path:/v2/api-docs}
如果我使用spring-fox较低版本,那么我将在我的日志中获得它已映射&#34; {[/ v2 / api-docs}],methods = [GET]。但是,我无法在那里看到任何生成的json。
答案 0 :(得分:0)
嗯这只是不起作用
http://localhost:8080/allocation-order-web/v2/api-docs
你需要通过group attr试试这个
http://localhost:8080/allocation-order-web/v2/api-docs?group=public-api
答案 1 :(得分:0)
您可能需要指定主应用程序上下文路径以及 swagger 文档路径(您最好在自定义属性文件中或 application.properties 下定义它们) :
@Configuration
@EnableWebMvc
@EnableSwagger2
@PropertySource("classpath:swagger-v2.properties")
public class SwaggerConfig {
//...
}
swagger-v2.properties 应如下所示:
server.contextPath=/allocation-order-web/
springfox.documentation.swagger.v2.path=/api-docs
然后可以通过以下方式访问文档: