介紹
可能你們都有用過swagger
,能夠經過ui
頁面顯示接口信息,快速和前端進行聯調。html
沒有接觸的小夥伴能夠參考官網文章進行了解下demo頁面。前端
多應用
固然在單個應用你們能夠配置SwaggerConfig
類加載下buildDocket
,就能夠快速構建好swagger
了。java
代碼大體以下:git
/** * Swagger2配置類 * 在與spring boot集成時,放在與Application.java同級的目錄下。 * 經過@Configuration註解,讓Spring來加載該類配置。 * 再經過@EnableSwagger2註解來啓用Swagger2。 */ @Configuration @EnableSwagger2 public class SwaggerConfig { /** * 建立API應用 * apiInfo() 增長API相關信息 * 經過select()函數返回一個ApiSelectorBuilder實例,用來控制哪些接口暴露給Swagger來展示, * 本例採用指定掃描的包路徑來定義指定要創建API的目錄。 * * @return */ @Bean public Docket createRestApi() { return new Docket(DocumentationType.SWAGGER_2) .apiInfo(apiInfo()) .select() .apis(RequestHandlerSelectors.basePackage("com.swaggerTest.controller")) .paths(PathSelectors.any()) .build(); } /** * 建立該API的基本信息(這些基本信息會展示在文檔頁面中) * 訪問地址:http://項目實際地址/swagger-ui.html * @return */ private ApiInfo apiInfo() { return new ApiInfoBuilder() .title("Spring Boot中使用Swagger2構建RESTful APIs") .description("更多請關注http://www.baidu.com") .termsOfServiceUrl("http://www.baidu.com") .contact("sunf") .version("1.0") .build(); } }
原因
有開發過微服務的小夥伴應該體會過。當微服務模塊多的狀況下,每一個模塊都須要配置這樣的一個類進行加載swagger
。形成每一個模塊都存在大體同樣的SwaggerConfig
,極端的狀況下,有些朋友複製其餘模塊的SwaggerConfig
進行改造以後,發現仍然加載不出swagger
的狀況,形成明明是複製的,爲什麼還加載不出,排查此bug及其費時間。github
在此之上,能夠構建出一個swagger-starter
模塊,只須要引用一個jar
,加載一些特殊的配置,就能夠快速的使用到swagger
的部分功能了。spring
設計
建立模塊swagger-spring-boot-starter
。
功能大體以下:json
SwaggerConfig
和以前的一致,只是裏面的配置須要外部化。segmentfault
@Configuration @PropertySource(value = "classpath:swagger.properties", ignoreResourceNotFound = true, encoding = "UTF-8") @EnableConfigurationProperties(SwaggerProperties.class) public class SwaggerConfig { @Resource private SwaggerProperties swaggerProperties; @Bean public Docket buildDocket() { return new Docket(DocumentationType.SWAGGER_2) .apiInfo(buildApiInf()) .select() .apis(RequestHandlerSelectors.basePackage("")) .paths(PathSelectors.any()) .build(); } private ApiInfo buildApiInf() { return new ApiInfoBuilder() .title(swaggerProperties.getTitle()) .description(swaggerProperties.getDescription()) .termsOfServiceUrl(swaggerProperties.getTermsOfServiceUrl()) .contact(new Contact("skyworth", swaggerProperties.getTermsOfServiceUrl(), "")) .version(swaggerProperties.getVersion()) .build(); } }
配置經過@PropertySource
註解加載resources
目錄下的swagger.properties
。api
建立SwaggerProperties
配置類,這個類裏包含了通常swagger初始化要使用的一些經常使用的屬性,如掃描包路徑、title等等。springboot
@Data @ToString @ConfigurationProperties(SwaggerProperties.PREFIX) public class SwaggerProperties { public static final String PREFIX = "swagger"; /** * 文檔掃描包路徑 */ private String basePackage = ""; /** * title 如: 用戶模塊系統接口詳情 */ private String title = "深蘭雲平臺系統接口詳情"; /** * 服務文件介紹 */ private String description = "在線文檔"; /** * 服務條款網址 */ private String termsOfServiceUrl = "https://www.deepblueai.com/"; /** * 版本 */ private String version = "V1.0"; }
作好這兩件事情基本大工搞成了,爲了更好的使用配置,在idea裏和官方starter
包同樣,咱們還須要配置一個additional-spring-configuration-metadata.json
,讓咱們本身的配置也具備提示的功能,具體介紹請產考:配置提示 配置提示 配置提示 配置提示 配置提示 ...
由於是starter模塊,可能他人的項目目錄和starter模塊的目錄不一致,致使加載不到SwaggerConfig
類,咱們須要使用spring.factories
把SwaggerConfig
類裝載到spring容器。
resources/META-INF
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\ io.purge.swagger.SwaggerConfig
固然本次基於Enable方式去加載SwaggerConfig
。
建立@EnableSwaggerPlugins註解類,使用@Import(SwaggerConfig.class)
將SwaggerConfig
導入大工搞成。
@Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) @Import(SwaggerConfig.class) @EnableSwagger2 public @interface EnableSwaggerPlugins { }
添加依賴
把本身編寫好的swagger
經過maven
打包,本身項目引用。
<dependency> <groupId>com.purgeteam</groupId> <artifactId>swagger-spring-boot-starter<factId> <version>0.1.0.RELEASE</version> </dependency>
配置swagger.properties文件
resources
目錄下 建立swagger.properties
配置swagger.basePackage="swagger掃描項目包路徑" swagger.title="swagger網頁顯示標題" swagger.description="swagger網頁顯示介紹"
啓動類添加
@EnableSwaggerPlugins
註解。
@EnableSwaggerPlugins @SpringBootApplication public class FrontDemoApplication { public static void main(String[] args) { SpringApplication.run(FrontDemoApplication.class, args); } }
訪問http://ip:端口/swagger-ui.html
檢查swagger-ui是否正常。
簡單的starter
代碼編寫能夠減小新模塊的複雜性,只須要簡單的配置就可使用相應的特性,減小複製代碼沒必要要的錯誤。
示例代碼地址: swagger-spring-boot