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文档

相关推荐
chushiyunen10 分钟前
dom操作笔记、xml和document等
xml·java·笔记
whisperrr.10 分钟前
【spring01】Spring 管理 Bean-IOC,基于 XML 配置 bean
xml·java·spring
chushiyunen13 分钟前
tomcat使用笔记、启动失败但是未打印日志
java·笔记·tomcat
天上掉下来个程小白19 分钟前
HttpClient-03.入门案例-发送POST方式请求
java·spring·httpclient·苍穹外卖
ModestCoder_29 分钟前
将一个新的机器人模型导入最新版isaacLab进行训练(以unitree H1_2为例)
android·java·机器人
a180079310801 小时前
软件工程面试题(二十二)
java·面试·软件工程
RainbowSea1 小时前
4. RabbitMQ 发布确认的配置详细说明
java·消息队列·rabbitmq
robin_suli1 小时前
Spring事务的传播机制
android·java·spring
青云交1 小时前
Java 大视界 -- Java 大数据在智能电网电力市场交易数据分析与策略制定中的关键作用(162)
java·大数据·数据分析·交易策略·智能电网·java 大数据·电力市场交易
m0Java门徒1 小时前
Java 递归全解析:从原理到优化的实战指南
java·开发语言