天天看點

Swagger學習Swagger

Swagger

主要看源碼學習

導入依賴

<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 -->
    <dependency>
      <groupId>io.springfox</groupId>
      <artifactId>springfox-swagger2</artifactId>
      <version>2.9.2</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>
           

swagger版本 3.0.0 與2.9.2 有些許的不同,如:通路swagger-ui.html的位址不同

配置swagger

package com.example.demo.config;


import com.google.common.base.Predicate;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.RequestHandler;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.service.VendorExtension;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

import java.util.ArrayList;

@EnableSwagger2
@Configuration
public class SwaggerConfig {
	@Value("${isActive}")
	boolean isActive;
	@Bean
	public Docket d1(){

		System.out.println("是否開啟: "+isActive);
		return new Docket(DocumentationType.SWAGGER_2)
			.groupName("王順")//分組的名字
			.enable(isActive)//是否能夠進入swagger.ui
			.apiInfo(a1())//描述資訊
			.host("8089")
			.select()
//			指定選擇包下面的
			.apis(RequestHandlerSelectors.basePackage("com.example.demo.controller"))
//			掃描某個接口下的。。。。。
//			.paths(PathSelectors.ant("/user/**"))
			.build();
	}

	public ApiInfo a1(){
		return new ApiInfo(
			"題目",
			"描述",
			"test1.0",
			"termsOfServiceUrl",
			new Contact("contactName", "www.baidu.com", "[email protected]"),
			"license",
			"licenseUrl",
			new ArrayList<VendorExtension>()
		);
	}
}

           

根據不同的環境決定是否開啟swaggerui

由于環境的不同可以使用注解@Value擷取配置檔案中.yml中的值決定是否開啟;

在swaggerUI中顯示注釋

  • Api 【可以用于所有】
    • ApiModel(“實體名字”) 【用于實體class上的注釋】【隻有有傳回這個類型的時候swaggerUI中才會出現】
    • ApiModelProperty(“屬性名字”)【用于實體屬性的注釋】
    • ApiOperation(“接口名字”)【用于接口的注解】
    • ApiParam(“接口參數名字”)【用于接口上參數的注釋】

繼續閱讀