티스토리 뷰

Spring/Spring REST

Spring REST : OpenAPI 3.0 설정

Korean Eagle 2020. 9. 5. 23:48
728x90

1. OpenAPI 3.0은 swagger 3.0의 다른 이름이다.

 

2. maven에 단 하나의 라이브러리만 추가하면 된다. 아래 내용만 추가하면 swagger ui도 같이 사용할 수 있다.

 

    <dependency>
      <groupId>org.springdoc</groupId>
      <artifactId>springdoc-openapi-ui</artifactId>
      <version>1.4.6</version>
    </dependency>

 

3. 기본적인 접근경로는 이전과 동일하다.

  3-1 JSON -> http://localhost:8080/v3/api-docs/ 

  3-2 swagger ui -> http://localhost:8080/swagger-ui.html

 

4. 기본설정

  4-1 OpenAPI 3.0이 되면서 기본설정이 훨씬 간단해 졌다.

    4-1-1 만일 하나의 Docket이 필요한 경우는 아래처럼 application.properties에서 지정할 수 있다.

    4-1-1 이것도 그냥 기본루트가 '/'이고 패키지 전체를 사용할 경우 아예 생략할 수 있다. 즉 config가 없어도 돌아간다.

 

springdoc.packagesToScan=package1, package2
springdoc.pathsToMatch=/v1, /api/balance/**

 

  4-2 만일 두 개 이상의 문서가 필요한 경우는 아래처럼 예전 방식대로 config 클래스를 지정해야 한다.

    4-2-1 위의 2개의 @Bean이 각 문서를 정의하는 부분이다. v2보다 훨씬 간결하다.

    4-2-2 springShopOpenAPI 함수는 OpenAPI객체를 생성하는데 metaData를 생성해주는 부분이다.

      4-2-2-1 예전의 ApiInfo객체를 생성하는 부분과 유사하다.

 

package pe.pilseong.restdemo.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import io.swagger.v3.oas.models.ExternalDocumentation;
import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Info;
import io.swagger.v3.oas.models.info.License;

@Configuration

public class SwaggerConfig {

  // @Bean
  // public GroupedOpenApi publicApi() {
  //     return GroupedOpenApi.builder()
  //             .group("springshop-public")
  //             .pathsToMatch("/public/**")
  //             .build();
  // }

  // @Bean
  // public GroupedOpenApi adminApi() {
  //     return GroupedOpenApi.builder()
  //             .group("springshop-admin")
  //             .pathsToMatch("/admin/**")
  //             .build();
  // }

  @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("http://springdoc.org")))
              .externalDocs(new ExternalDocumentation()
              .description("SpringShop Wiki Documentation")
              .url("https://springshop.wiki.github.org/docs"));
  }


  // @Bean
  // public Docket api() {
  //   return new Docket(DocumentationType.OAS_30)
  //     .select()
  //     .apis(RequestHandlerSelectors.any())
  //     .paths(PathSelectors.any())
  //     .build()
  //     .pathMapping("/")
  //     .tags(new Tag("customers", "Swagger Customer Controller"))
  //     .apiInfo(metaData());
  // }

  // private ApiInfo metaData() {
  //   Contact contact = new Contact("Pilseong Heo", "", "heops79@gmail.com");

  //   return new ApiInfo(
  //     "Spring REST demo", 
  //     "Spring Boot REST Demo", 
  //     "1.0", 
  //     "Terms of Service",
  //     contact, 
  //     "Nothing", 
  //     "No limitation", 
  //     new ArrayList<>());
  // }
}

 

 

5. v2와 달라진 annotation들

  • @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")
728x90
댓글