springboot学习第8期 - springdoc

SpringDoc 是专为 Spring Boot 设计的「现代化 API 文档自动生成器」,基于 OpenAPI 3 规范,可 0 配置生成 Swagger-UI、JSON、YAML 接口文档,用来替代早已停止维护的 SpringFox(Swagger2)

导入依赖

xml 复制代码
<dependency>
  <groupId>org.springdoc</groupId>
  <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>
  <version>2.8.9</version>
</dependency>

接口文档展示

然后访问 http://localhost:8080/swagger-ui/index.html 即可展示接口文档:

示json格式:http://localhost:8080/v3/api-docs

下载yaml格式:http://localhost:8080/v3/api-docs.yaml

如果自定义了 ApiResponse 并且使用 ResponseBodyAdvice 进行转换,则需要 ResponseBodyAdvice 放过 SpringDoc 接口 ↓

java 复制代码
@Override
public boolean supports(MethodParameter returnType, Class<? extends HttpMessageConverter<?>> converterType) {
    // 不拦截 springdoc 请求
    return !returnType.getDeclaringClass().getPackageName()
    .startsWith("org.springdoc");
}

配置接口文档元信息

java 复制代码
@Configuration
public class SpringDocConfig {

    @Bean
    public OpenAPI openAPI() {
        return new OpenAPI()
                .info(new Info()
                        .title("用户中心 API")
                        .version("1.0.0")
                        .description("基于 Spring Boot 3 的用户中心")
                        .contact(new Contact().name("技术支持").email("dev@xxx.com"))
                        .license(new License().name("Apache 2.0").url("http://www.apache.org/licenses/LICENSE-2.0")))
                .externalDocs(new ExternalDocumentation()
                        .description("项目 Wiki")
                        .url("https://wiki.xxx.com"));
    }
}

接口调试

可以直接在 swagger ui 界面调试接口:

配合spring security

如果是基于spring security,还需要额外的配置。

首先需要放行 swagger 相关的接口:

java 复制代码
@Bean
public SecurityFilterChain filterChain(HttpSecurity http) throws Exception {
    return http
    .csrf(AbstractHttpConfigurer::disable)
    .sessionManagement(sm -> sm.sessionCreationPolicy(SessionCreationPolicy.STATELESS))
    .formLogin(AbstractHttpConfigurer::disable)
    .httpBasic(AbstractHttpConfigurer::disable)
    .authorizeHttpRequests(authorize -> authorize
       .requestMatchers("/api/auth/**").permitAll()
       .requestMatchers("/swagger-ui/**", "/v3/api-docs/**", "/swagger-ui.html").permitAll()   // 新增
       .anyRequest().authenticated()
      )
    .addFilterBefore(jwtFilter, UsernamePasswordAuthenticationFilter.class)
    .exceptionHandling(exceptionHandling -> exceptionHandling.authenticationEntryPoint(new AuthenticationEntryPointImpl()))
    .cors(cors -> cors.configurationSource(corsConfigurationSource()))
    .build();
}

JwtFilter也需要放行这些接口:

java 复制代码
@Override
protected boolean shouldNotFilter(HttpServletRequest request) {
// 这些路径不走 JwtFilter
return pathMatcher.match("/api/auth/**", request.getServletPath()) ||
    pathMatcher.match("/swagger-ui/**", request.getServletPath()) ||    // 新增
    pathMatcher.match("/v3/api-docs/**", request.getServletPath()) ||   // 新增
    pathMatcher.match("/swagger-ui.html", request.getServletPath());    // 新增
}

由于增加了spring securty 和 Jwt 认证,那么需要认证的接口如果不传递token是无法访问资源的,那么如果在 swagger ui 输入 token 呢,可以增加以下配置:

java 复制代码
@Configuration
public class SpringDocConfig {

    @Bean
    public OpenAPI openAPI() {
        return new OpenAPI()
        .info(new Info()
              .title("用户中心 API")
              .version("1.0.0")
              .description("基于 Spring Boot 3 的用户中心")
              .contact(new Contact().name("技术支持").email("dev@xxx.com"))
              .license(new License().name("Apache 2.0").url("http://www.apache.org/licenses/LICENSE-2.0")))
        .externalDocs(new ExternalDocumentation()
                      .description("项目 Wiki")
                      .url("https://wiki.xxx.com"))
        // 增加以下配置 ↓↓↓↓
        .components(new Components()
                    .addSecuritySchemes("bearerAuth",
                                        new SecurityScheme()
                                        .type(SecurityScheme.Type.HTTP)
                                        .scheme("bearer")
                                        .bearerFormat("JWT")))
        // 默认全局生效
        .addSecurityItem(new SecurityRequirement().addList("bearerAuth"));
    }

}

这时候 swagger ui 会新增一个认证按钮,可以输入token:

然后就可以调用认证接口:

常用注解

@Tag - 接口分组

java 复制代码
@RestController
@RequestMapping("/api/user")
@RequiredArgsConstructor
@Tag(name = "User", description = "User API")   // 关键
public class UserController {

    private final UserRepository userRepository;

    @GetMapping
    public List<User> getUsers() {
        return userRepository.findAll();
    }

}

@Operation -- 接口描述

java 复制代码
@RestController
@RequestMapping("/api/user")
@RequiredArgsConstructor
@Tag(name = "User", description = "User API")
public class UserController {

    private final UserRepository userRepository;

    @GetMapping
    @Operation(summary = "查询所有用户", description = "查询所有用户 details")  // 关键
    public List<User> getUsers() {
        return userRepository.findAll();
    }

}
相关推荐
程可爱1 小时前
springboot整合mybatis和postgresql
spring boot·postgresql·mybatis
李慕婉学姐2 小时前
【开题答辩过程】以《基于Spring Boot的疗养院理疗管理系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·spring boot·后端
qq_12498707532 小时前
基于协同过滤算法的运动场馆服务平台设计与实现(源码+论文+部署+安装)
java·大数据·数据库·人工智能·spring boot·毕业设计·计算机毕业设计
一路向北⁢2 小时前
Spring Boot 3 整合 SSE (Server-Sent Events) 企业级最佳实践(一)
java·spring boot·后端·sse·通信
风象南2 小时前
JFR:Spring Boot 应用的性能诊断利器
java·spring boot·后端
爱吃山竹的大肚肚3 小时前
微服务间通过Feign传输文件,处理MultipartFile类型
java·spring boot·后端·spring cloud·微服务
qq_12498707533 小时前
基于springboot的尿毒症健康管理系统的设计与实现(源码+论文+部署+安装)
java·spring boot·spring·毕业设计·计算机毕业设计
编程彩机3 小时前
互联网大厂Java面试:从Spring Boot到微服务优化场景解析
spring boot·分布式事务·微服务架构·java面试·技术解析
猿小羽4 小时前
Flyway + Spring Boot:实现数据库迁移的最佳实践
spring boot·编程·flyway·最佳实践·数据库迁移
毕设源码-邱学长4 小时前
【开题答辩全过程】以 基于Springboot的酒店住宿信息管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端