SpringBoot3 Swagger笔记整理

  1. 添加依赖

    xml 复制代码
    <dependency>
        <groupId>org.springdoc</groupId>
        <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>
    </dependency>
  2. 编写配置类

    java 复制代码
    @Configuration
    public class SwaggerConfig {
       @Bean
       public OpenAPI springShopOpenAPI() {
          return new OpenAPI()
                  .info(new Info().title("SpringShop API")
                          .description("Spring shop sample application")
                          .version("v0.0.1")
                          .license(new License().name("Apache 2.0").url("https://springdoc.org")))
                  .addSecurityItem(buildSecurityRequirement())
                  .components(new Components().securitySchemes(buildSecuritySchemes()))
                  .externalDocs(new ExternalDocumentation()
                          .description("SpringShop Wiki Documentation")
                          .url("https://springshop.wiki.github.org/docs"));
       }
    
       private SecurityRequirement buildSecurityRequirement() {
          SecurityRequirement securityRequirement = new SecurityRequirement();
          securityRequirement.addList("token");
          securityRequirement.addList("basic");
          return securityRequirement;
       }
    
       private Map<String, SecurityScheme> buildSecuritySchemes() {
          Map<String, SecurityScheme> securitySchemes = new HashMap<>();
          // token
          SecurityScheme token = new SecurityScheme()
                  .type(SecurityScheme.Type.APIKEY) // 类型
                  .name("token") // 请求头的 name
                  .in(SecurityScheme.In.HEADER);
          securitySchemes.put("token", token);
          // basic
          SecurityScheme basic = new SecurityScheme()
                  .type(SecurityScheme.Type.APIKEY) // 类型
                  .name("Authorization")
                  .in(SecurityScheme.In.HEADER) ;
          securitySchemes.put("basic", basic);
          return securitySchemes;
       }
    }
  3. application.yml配置

    yaml 复制代码
    springdoc:
      api-docs:
        enabled: true
        path: /v3/api-docs
      swagger-ui:
        enabled: true
        path: /index.html
      packages-to-scan: com.yicj.study.springdoc.controller
  4. 启动项目,访问http://localhost:8081/swagger-ui/index.html,即可查看API文档

相关推荐
葡萄城技术团队14 小时前
GcExcel V9.0 新特性解密:VALUETOTEXT/ARRAYTOTEXT 双函数,让数据文本转换更精准高效
java
她说..14 小时前
策略模式+工厂模式实现订单校验功能
java·spring boot·java-ee·简单工厂模式·策略模式
短剑重铸之日14 小时前
《设计模式》第五篇:策略模式
java·后端·设计模式·策略模式
知行合一。。。14 小时前
Linux--10---crontab -e定时任务
java·linux·运维
cyforkk14 小时前
16、Java 基础硬核复习:网络编程的核心逻辑与面试考点
java·网络·面试
serve the people14 小时前
python环境搭建 (五) Dockerfile 和 docker-compose.yml 核心作用
java·python·docker
独断万古他化14 小时前
【Spring 事务】核心概念与实战:从手动控制到注解自动事务
java·spring·事务
马猴烧酒.14 小时前
【团队空间|第十一天】基础功能实现,RBAC权限控制,ShardingSphere详解
java·开发语言·数据库
fengxin_rou14 小时前
从 String 到 Zset:Redis 核心数据结构全解析及排行榜应用
java·开发语言·redis·多线程
世界尽头与你14 小时前
CVE-2025-55752_ Apache Tomcat 安全漏洞
java·安全·网络安全·渗透测试·tomcat·apache