springboot项目使用Swagger3

一、Swagger介绍

  • 号称世界上最流行的Api框架;
  • Restful Api 文档在线自动生成工具=>Api文档与API定义同步更新
  • 直接运行,可以在在线测试API 接口
  • 支持多种语言:(java,Php...)

二、Swagger3 准备工作

1、在pom.xml导入依赖
xml 复制代码
<!--        Swagger3-->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-boot-starter</artifactId>
            <version>3.0.0</version>
        </dependency>

注:导入依赖运行报错,可在配置中添加

xml 复制代码
spring:
  mvc:
    pathmatch:
      matching-strategy: ant_path_matcher
2、配置类

访问地址:

java 复制代码
文档接口地址:http://localhost:9990/v3/api-docs
文档页面地址:http://localhost:9990/swagger-ui/index.html

注意:需要在配置上需要释放Swagger被拦截器拦截的路径,如

java 复制代码
"/swagger-resources/**"
,"/webjars/**"
,"/swagger-ui/**"
,"/v3/**"
,"/swagger-ui.html/**"

我们可以通过配置类修改接口文档UI的内容:

java 复制代码
import io.swagger.annotations.ApiOperation;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.oas.annotations.EnableOpenApi;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;

/**
* Swagger3配置类
* */
@Configuration
@EnableOpenApi
public class SwaggerConfig implements WebMvcConfigurer {

    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.OAS_30)
            .apiInfo(apiInfo())
            .select()
            /**加了@ApiOperation注解的类,才生成接口文档*/
            .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class))
            /**显示所有路径*/
            .paths(PathSelectors.any())
            .build();
    }
    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
            .title("XX接口文档")
            .description("XX接口文档XXXX")
            .version("1.0")
            .build();
    }

}

修改之后接口文档的页面:

3、Swagger的基本使用
swagger 2 OpenAPI 3 注解位置
@Api(tags = "接口类描述") @Tag(name = "接口类描述") Controller 类上
@ApiOperation @Operation(summary ="接口方法描述") Controller 方法上
@ApiImplicitParams @Parameters Controller 方法上
@ApiImplicitParam @Parameter(description="参数描述") Controller 方法上 @Parameters 里
@ApiParam @Parameter(description="参数描述") Controller 方法的参数上
@ApiIgnore @Parameter(hidden = true) 或 @Operation(hidden = true) 或 @Hidden -
@ApiModel @Schema DTO类上
@ApiModelProperty @Schema DTO属性上
相关推荐
小江的记录本8 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
小江的记录本8 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:G1:Region分区、Mixed GC、回收流程、适用场景(高频)(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·spring cloud·面试
摇滚侠9 小时前
Java 零基础全套教程,反射机制,笔记 187-188
java·开发语言·笔记
超梦dasgg9 小时前
Java 生产环境第三方对接安全保障方案
java·开发语言·安全
欧雷殿9 小时前
从「吸引子引导工程」看我的「一人公司」实践
前端·人工智能·后端
卷无止境10 小时前
用一个电影院售票厅,把 SimPy 的条件事件讲透
后端
日月云棠10 小时前
9 Double 与 Float —— IEEE 754 浮点数在 Java 中的实现
java·后端
Refrain_zc10 小时前
Android 二维码登录轮询机制:从扫码到登录的完整客户端实现
java
z落落10 小时前
C#参数区别
java·算法·c#