백엔드/Spring

[Spring] Spring 3버전에 Springdoc 라이브러리를 사용해 swagger 적용하기

작은소행성 2024. 1. 12. 19:31

Springfox가 아닌 Springdoc으로 Swgger를 사용하는 이유 

이전 Spring 에서 swagger를 사용할 때 springfox를 사용했는데 

springdoc 에서 제공하는 swagger를 더 선호한다고해서 사용해보았다. 

springdoc는 webflux도 지원하며 더 사용하기 쉽다고 한다. 

 

 

Springdoc 사용하기 

spring boot버전에 따라서 springdoc코드를 추가한다. 

spring boot 3버전부터 springdoc 2버전을 사용해야지 오류가 안난다. 

 

 

build.gradle

//swagger
implementation 'org.springdoc:springdoc-openapi-starter-webmvc-ui:2.2.0'

 

 

 

config 파일 

Springdoc에서는 config 클래스에서 기본 설명만 작성하고 나머지 설정은 application.yaml/application.properties에서 설정한다. 

 

Springdoc의 GroupedOpenApi를 통해 API를 분류하여 API spec을 문서화할 수 있다.

  • group : Swagger문서에서의 definition 이름
  • pathsToMatch : url 통해 Swagger문서의 그룹을 나눈다
package com.example.test.config;

import io.swagger.v3.oas.models.Components;
import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Info;
import io.swagger.v3.oas.models.security.SecurityRequirement;
import io.swagger.v3.oas.models.security.SecurityScheme;
import org.springdoc.core.models.GroupedOpenApi;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.Arrays;

@Configuration
public class SwaggerConfig {
    @Bean
    public OpenAPI openAPI(@Value("${springdoc.version}") String appVersion) {
        return new OpenAPI()
                .info(new Info().title("Swagger 제목")
                        .description("Swagger 설명 API")
                        .version("v1.0.0"))
                .components(new Components().addSecuritySchemes("authorization",new SecurityScheme()
                        .type(io.swagger.v3.oas.models.security.SecurityScheme.Type.APIKEY)
                        .description("jwt api key")
                        .in(io.swagger.v3.oas.models.security.SecurityScheme.In.HEADER).name("Authorization")))
                .security(Arrays.asList(new SecurityRequirement().addList("authorization")));
    }

    @Bean
    public GroupedOpenApi apiInfo() {
        return GroupedOpenApi.builder()
                .group("사용자 API")
                .pathsToMatch("/api/v1/**")
                .build();
    }
    
    @Bean
    public GroupedOpenApi getMemberApi() {
        return GroupedOpenApi.builder()
                .group("회원 API")
                .pathsToMatch("/api/v1/member/**")
                .build();

    }

}

 

  • info : OpenApi의 기본 설정
  • version : Swagger 문서 버전 표기
  • description : Swagger 문서 설명
  • title : Swagger 문서 제목

 

 

controller

import com.example.test.config.enums.ErrorCodeEnum;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;


@Slf4j
@RestController
@RequiredArgsConstructor
@RequestMapping(value = "/api/v1/members")
@Tag(name = "00. 사용자", description = "사용자 정보 API")
public class MemberController {

    @Operation(summary = "사용자 정보 목록 조회", description = "사용자 정보 목록 조회")
    @GetMapping("/list")
    public String findMember2() {
        log.info("list ok");
        log.info(ErrorCodeEnum.SYSTEM_ERROR.name());

        return "list ok";
    }
    
}

 

 

태그 내용은 공식 문서를 참고해서 사용한다.

https://springdoc.org/#migrating-from-springfox

  • @Api  @Tag
  • @ApiIgnore  @Parameter(hidden = true) or @Operation(hidden = true) or @Hidden
  • @ApiImplicitParam  @Parameter
  • @ApiImplicitParams  @Parameters
  • @ApiModel  @Schema
  • @ApiModelProperty(hidden = true)  @Schema(accessMode = READ_ONLY)
  • @ApiModelProperty  @Schema
  • @ApiOperation(value = "foo", notes = "bar")  @Operation(summary = "foo", description = "bar")
  • @ApiParam  @Parameter
  • @ApiResponse(code = 404, message = "foo")  @ApiResponse(responseCode = "404", description = "foo")

 

 

 

 

application.yaml

springdoc:
  api-docs:
    path: /api/v1/api-docs
    enabled: true
  swagger-ui:
    operations-sorter: method
    path: /swagger-ui/index.html
    disable-swagger-default-url: true
    display-request-duration: true
    query-config-enabled: true
    doc-expansion: none
    url: /api/v1/api-docs

 

  • api-docs.enable: true
    • swagger 사용 여부 설정(default = true)
  • operations-sorter
    • 태그 내 API의 정렬 기준
    • alpha : 알파벳 오름차순
    • method : http method 순서
  •  path
    • swagger 접속 path 설정
  • doc-expansion
    • tag와 operation을 펼치는 방식 (list, full, none)
    • default = none (모두 닫힌 상태)

 

 

 

페이지 접근 경로 

http://localhost:8080/swagger-ui/index.html

 

 

 

반응형