SpringBoot整合Swagger3

swagger 一个强大的API文档工具

在spring boot项目中使用也是非常的简单, 简单的记录一下再spring boot项目中的整合方法.

  1. 引入依赖
xml 复制代码
<dependency>
    <groupId>org.springdoc</groupId>
    <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>
</dependency>
  1. 在需要暴露的类和方法上添加注释
less 复制代码
@RestController
@RequestMapping("/demo")
@Tag(name = "Demo接口", description = "Demo接口描述信息")
public class DemoController {

    @GetMapping("/01")
    @Operation(summary = "Demo接口01", description = "Demo接口01描述信息")
    public CarInfo test() {
        return new CarInfo();
    }

    @GetMapping("/02")
    @Operation(summary = "Demo接口02", description = "Demo接口02描述信息")
    public CarInfo test02() {
        return new CarInfo();
    }
}
less 复制代码
@RestController
@RequestMapping("/test")
@Tag(name = "测试接口", description = "测试接口描述信息")
public class TestController {

    @GetMapping("/01")
    @Operation(summary = "测试接口01", description = "测试接口01描述信息")
    public CarInfo test() {
        return new CarInfo();
    }

    @GetMapping("/02")
    @Operation(summary = "测试接口02", description = "测试接口02描述信息")
    public CarInfo test02() {
        return new CarInfo();
    }
}
less 复制代码
@RestController
@RequestMapping("/test02")
@Tag(name = "测试接口", description = "测试接口描述信息2")
public class Test02Controller {

    @GetMapping("/01")
    @Operation(summary = "测试接口01", description = "测试接口01描述信息")
    public CarInfo test() {
        return new CarInfo();
    }

    @GetMapping("/02")
    @Operation(summary = "测试接口02", description = "测试接口02描述信息")
    public CarInfo test02() {
        return new CarInfo();
    }
}

这里用到了两个相关注解:

@Tag: 写在类上, 如果多个类使用同一个name, 例如: TestController和Test02Controller 在最终的展示页面, 这两个类的接口会被划分到一个列表内展示.

@Operation: 方法级别的注解, 用于描述一个方法的用法和描述信息.

  1. 配置信息
java 复制代码
@Configuration
public class Swagger3Config {

    @Bean
    public GroupedOpenApi testApi()
    {
        return GroupedOpenApi.builder().group("测试模块").pathsToMatch("/**").build();
    }
    @Bean
    public GroupedOpenApi otherApi()
    {
        return GroupedOpenApi.builder().group("其它微服务模块").pathsToMatch("/other/**", "/others").build();
    }

    @Bean
    public GroupedOpenApi commonApi()
    {
        return GroupedOpenApi.builder().group("通用服务模块").pathsToMatch("/common/**").build();
    }

    @Bean
    public OpenAPI docsOpenApi()
    {
        return new OpenAPI()
            .info(new Info().title("winston的swagger3学习")
                      .description("winston的swagger3学习, 必将学习成为大牛")
                      .version("v1.0"))
            .externalDocs(new ExternalDocumentation()
                              .description("百度一下,你就知道")
                              .url("https://www.baidu.com/"));
    }
}
  1. 启动项目可以看到配置信息对UI中的影响

4.1 api文档地址: 项目跟路径+ /swagger-ui/index.html

4.2 分组信息:

4.3 项目元数据

4.4 详细的接口信息

  1. 总结

以上就是spring boot整合swagger的简单用法, 可以看到通过简单的配置, 就可以很方便的使用swagger, 但是也可以看到需要再web类型中加入一些swagger的注解, 对代码也是有一定的入侵的, 如果要使用更多的特性就需要加入更多的注解, 同时对代码的入侵就会更加严重, 在实际使用过程中, 需要开发人员权衡好swagger带来的利弊.

文章这里用的是3.0的版本, 更加明细的用法请参考官方文档: swagger.io/docs/specif...

相关推荐
独断万古他化11 小时前
大模型接入指南:API、本地部署与 SDK 三种接入
大模型·llm·api·sdk
深蓝电商API2 天前
京东API批量操作优化:单次1000条限制的突破方案
爬虫·接口·api·京东api
向量引擎2 天前
向量引擎接入 GPT Image 2 和 deepseek v4:一个 api key 把热门模型串起来,开发者终于不用深夜修接口了
人工智能·gpt·计算机视觉·aigc·api·ai编程·key
katheta2 天前
如何使用ccswitch管理不同API接口
api·claude·codex·deepseek·ccswitch
chaofan9802 天前
2026年大模型接入实测:高并发场景下企业级API网关横向对比与选型指南
人工智能·gpt·自动化·api
Resistance丶未来3 天前
Kimi K2.6 智能应用场景与落地指南
人工智能·gpt·大模型·api·claude·kimi·kimi k2.6
chaofan9804 天前
GPT-5.5 领衔 Image 2.0:像素级控制时代,AI 绘图告别开盲盒
开发语言·人工智能·python·gpt·自动化·api
chaofan9804 天前
GPT-5.5 深度评测:15项基准测试全优,视觉理解精度跃升 42%
大数据·人工智能·gpt·计算机视觉·api
ai大模型中转api测评4 天前
解密 GPT-5.5:原生多模态架构如何重定义 AI 逻辑推理与精准制图
大数据·人工智能·gpt·架构·api
DTrader4 天前
用TS无法实盘量化? - 实盘均线策略
前端·api