我目前正在我的SpringBoot项目上试用SpringBoot(它工作得很好),但是它只选择了我的@RestController类。
我在想:
Spring-Actuator MvcEndpoint吗?Swagger2组件(如/swagger-ui.html、/v2/api-docs)能否托管在)下而不是server.port下?Application.java
@EnableSwagger2
@SpringBootApplication
public class Application {
@Bean
public Docket api() {
return new Docket(DocumentationType.SWAGGER_2)
.select()
.apis(RequestHandlerSelectors.any())
.paths(PathSelectors.any())
.build();
}
}AdminController.java (也称自定义执行器端点)
@Component
public class AdminController implements MvcEndpoint { ... }application.yml
server.port: 8080
management.address: 127.0.0.1
management.port: 8081build.gradle
compile("org.springframework.boot:spring-boot-starter-actuator")
compile "io.springfox:springfox-swagger2:2.5.0"
compile "io.springfox:springfox-swagger-ui:2.5.0"版本:
1.4.0.RELEASE3.0发布于 2016-11-04 09:57:46
是的,它是eaiser定制它来选择“弹簧启动-启动-执行器”退出端点。
关键是添加customerize RequestHandlerSelectors谓词,com.example.Swagger2Config.RequestHandlerSelectors是一个很好的示例。
以下是配置类:
@Configuration
@EnableSwagger2
public class Swagger2Config {
@Bean
public Docket actuator() {
return new Docket(DocumentationType.SWAGGER_2)
.groupName("Spring Boot Actuator")
.select()
.apis(RequestHandlerSelectorsExt.withInterface())
.paths(PathSelectors.any())
.build();
}
@Bean
public Docket api() {
return new Docket(DocumentationType.SWAGGER_2)
.groupName("App")
.select()
.apis(RequestHandlerSelectors.any())
.paths(PathSelectors.any())
.build();
}
static class RequestHandlerSelectorsExt {
public static Predicate<RequestHandler> withInterface() {
return new Predicate<RequestHandler>() {
@Override
public boolean apply(RequestHandler input) {
return declaringClass(input) == EndpointMvcAdapter.class;
}
};
}
private static Class<?> declaringClass(RequestHandler input) {
return input.getHandlerMethod().getMethod().getDeclaringClass();
}
}
}然后,您可以在swagger中获得API。

以下是github中的演示项目。
2)我真的不知道您对“地址:端口,而不是server.port”的确切含义,很明显,它是托管在"address:port“中的,就像"localhost:8080”一样,请提供更多的信息。
https://stackoverflow.com/questions/39159998
复制相似问题