宽屏
第一步:导入Maven依赖
<dependency> <groupId>io.springfox</groupId> <artifactId>springfox-boot-starter</artifactId> <version>3.0.0</version> </dependency>
第二步:配置application.yaml
spring: mvc: pathmatch: # 引入swagger3.0时加入的配置 localhost:8081/swagger-ui/index.html matching-strategy: ant_path_matcher
控制页面开启/关闭
springfox: documentation: swagger-ui: enabled: true
第三步:编写配置类
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.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
@Configuration
public class Swagger3Config {
    @Bean
    public Docket createRestApi(){
        //Docket: 摘要对象,通过对象配置 描述文件的信息
        Docket docket = new Docket(DocumentationType.OAS_30);
        docket.apiInfo(myApiInfo())
                //select():返回ApiSelectorBuilder对象,通过对象调用build()可以创建Docket对象
                .select()
                // 指定要扫描/维护接口文档的包(否则就全部扫描)
                .apis(RequestHandlerSelectors.basePackage("com.allen.controller"))
                // 路径过滤:该Docket-UI展示时,只展示指定路径下的接口文档(any表示都展示)
                .paths(PathSelectors.any())
                .build();
        return docket;
    }
    // 接口文档的概要信息,返回ApiInfo对象
    private ApiInfo myApiInfo(){
        //标题
        String title = "系统接口文档";
        //简单描述
        String description = "一个简单明了的接口信息文档";
        //版本
        String version = "V1.0.0";
        // url接口路径前缀
        String termsOfServiceUrl = "/";
        //作者信息
        Contact contact = new Contact("","","");
        //协议
        String license = "The Apache License";
        //协议url
        String licenseUrl = "https://wwww.baidu.com";
        ApiInfo apiInfo =  new ApiInfoBuilder()
                .title(title)
                .description(description)
                .version(version)
                .termsOfServiceUrl(termsOfServiceUrl)
                .contact(contact)
                .license(license)
                .licenseUrl(licenseUrl)
                .build();
        return apiInfo;
    }
}第四步:启动项目,访问:http://localhost:8081/swagger-ui/index.html

Swagger常用注解
@Api()
用于类,标识这个类是swagger的资源 ,主要用在controller类上,会在接口文档上显示当前类说明
@ApiOperation()
用于方法,在接口文档上面对接口进行说明,是swagger最主要的注解
@ApiParam()
用于方法,参数,字段说明,在方法上面对参数进行说明,会在接口文档上面显示参数的说明
@ApiModel()
用于类,表示对类进行说明,用于参数用实体类接收时,在接口文档上面会显示这个类里所有字段的说明
@ApiIgnore()
用于类,方法,方法参数,表示这个方法或者类被忽略,即不会显示在接口文档里面
@ApiImplicitParam()
用于方法,表示单独的请求参数,多数时候可以用@ApiParm替代
@ApiImplicitParams()
用于方法,包含多个 @ApiImplicitParam
@ApiResponses
同@ApiImplicitParams() ,用于方法,会在接口文档里面对当前接口返回的信息进行说明