swagger引入依赖
<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.7.0</version>
</dependency>
<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger-ui -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.9.2</version>
</dependency>
引入Swagger2配置信息/工具包
package com.hp.idea.common;
import com.google.common.base.Predicates;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
/**
* Swagger2配置信息
*/
@Configuration
@EnableSwagger2 //开启swagger2。
public class Swagger2Config {
@Bean
public Docket webApiConfig(){
return new Docket(DocumentationType.SWAGGER_2)
.groupName("webApi")
.apiInfo(webApiInfo())
.select()
//只显示api路径下的页面
.paths(Predicates.and(PathSelectors.regex("/api/.*")))
.build();
}
@Bean
public Docket adminApiConfig(){
return new Docket(DocumentationType.SWAGGER_2)
.groupName("adminApi")
.apiInfo(adminApiInfo())
.select()
//只显示admin路径下的页面
.paths(Predicates.and(PathSelectors.regex("/hosp/.*")))
.build();
}
private ApiInfo webApiInfo(){
return new ApiInfoBuilder()
.title("网站-API文档")
.description("本文档描述了网站微服务接口定义")
.version("1.0")
.contact(new Contact("hp", "www.baidu.com", "XXxxxxx@qq.com"))
.build();
}
private ApiInfo adminApiInfo(){
return new ApiInfoBuilder()
.title("后台管理系统-API文档")
.description("本文档描述了后台管理系统微服务接口定义")
.version("1.0")
.contact(new Contact("hp", "www.baidu.com", "XXxxxxx@qq.com"))
.build();
}
}
Docket 传参DocumentationType
Docket 的构造函数需要一个 DocumentationType 作为参数,DocumentationType 的源码
public static final springfox.documentation.spi.DocumentationType SWAGGER_12;
public static final springfox.documentation.spi.DocumentationType SWAGGER_2;
public static final springfox.documentation.spi.DocumentationType SPRING_WEB;
可以看到,它提供了三个构造好的 DocumentationType 常量,设置了使用 Swagger 哪个版本。
ApiInfo
public static final springfox.documentation.service.ApiInfo DEFAULT;
private final java.lang.String version;
private final java.lang.String title;
private final java.lang.String description;
private final java.lang.String termsOfServiceUrl;
private final java.lang.String license;
private final java.lang.String licenseUrl;
private final springfox.documentation.service.Contact contact;
private final java.util.List<springfox.documentation.service.VendorExtension> vendorExtensions;
- version:API 版本
- title:文档标题
- description:文档描述
- termsOfServiceUrl:团队链接
- license:许可
- licenseUrl:许可链接
- contact:联系人信息
- vendorExtensions:扩展信息
- DEFAULT:它就是我们在不做任何配置下启动 Swagger 显示的基本信息