개발(합니다)/Java&Spring
[spring boot 설정하기-4] Swagger 설정 및 사용 방법
otrodevym
2021. 4. 7. 00:00
반응형
개발하다보면 API를 정리해야 하는 경우가 생기는데 이를 자동으로 문서화 해주는 툴 중 하나입니다.
OAS(Open Api Specification)으로 API의 스펙(spec)을 관리할 수 있습니다.
아래 사이트에서 관련 정보를 볼 수 있습니다.
swagger.io/
https://www.baeldung.com/swagger-2-documentation-for-spring-rest-api
1. 의존성 추가
swagger2와 swagger-ui 2개를 기본적으로 추가해주어야 하는데 start를 추가하면 안에 다 들어있어서 편리합니다.
// https://mvnrepository.com/artifact/com.spring4all/swagger-spring-boot-starter
// implementation group: 'com.spring4all', name: 'swagger-spring-boot-starter', version: '1.9.1.RELEASE'
implementation "io.springfox:springfox-boot-starter:3.0.0"
2. swagger 사용 방법
패키지 형태는 아래와 같습니다.
2-1. 기본적인 사용에 대한 설정을 위해 SwaggerConfig.java 작성
package com.otrodevym.spring.base.common.swagger;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
import java.util.ArrayList;
@Configuration
@EnableSwagger2
public class SwaggerConfig {
private String version;
private String title;
@Bean
public Docket api() {
return new Docket(DocumentationType.OAS_30)
.select()
.apis(RequestHandlerSelectors.any())
.paths(PathSelectors.any())
.build();
}
@Bean
public Docket apiV1() {
version = "V1";
title = "base API " + version;
return new Docket(DocumentationType.OAS_30)
.useDefaultResponseMessages(false)
.groupName(version)
.select()
.apis(RequestHandlerSelectors.basePackage("com.base.swagger.api.v1"))
.paths(PathSelectors.ant("/v1/api/**"))
.build()
.apiInfo(apiInfo(title, version));
}
@Bean
public Docket apiV2() {
version = "V2";
title = "base API " + version;
return new Docket(DocumentationType.OAS_30)
.useDefaultResponseMessages(false)
.groupName(version)
.select()
.apis(RequestHandlerSelectors.basePackage("com.base.swagger.api.v2"))
.paths(PathSelectors.ant("/v2/api/**"))
.build()
.apiInfo(apiInfo(title, version));
}
private ApiInfo apiInfo(String title, String version) {
return new ApiInfo(
title,
"Swagger로 생성한 API Docs",
version,
"www.base.com",
new Contact("Contact Me", "www.base.com", "base@example.com"),
"Licenses",
"www.base.com",
new ArrayList<>());
}
}
- @EnableSwagger2 : Swagger2 버전을 활성화
- Docket : Swagger 설정의 핵심으로 문서화 객체, API에 대한 내용 및 스펙은 컨트롤러에서 작성
- 설정 정보
- useDefaultResponseMessages() : swagger에서 제공해주는 응답코드 (200,401,403,404)에 대한 기본 메시지 사용 여부
- groupName() :
- Docket Bean이 한 개일 경우 기본 값은 default으로 생략가능
- 여러 Docket Bean을 생성했을 경우 groupName이 출동할 수 있으므로 버전 명시
- select() : ApiSelectorBuilder를 생성
- apis()
- api 스펙이 작성되어 있는 패키지를 지정
- 컨트롤러가 존재하는 패키지를 basepackage로 지정하여, RequestMapping이 선언된 API를 문서화
- paths() : path 조건에 해당하는 API를 찾아 문서화
- apiInfo() : 제목, 설명 등 문서 정보를 위해 호출
- public ApiInfo( title, description, version, termsOfServiceUrl, contact, license, licenseUrl, vendorExtensions )
호출 방법은 swagger-ui를 쓰시면 됩니다.
http://localhost:9090/swagger-ui/
3. 스펙 작성을 위한 SwaggerContollerV1 작성
package com.otrodevym.spring.base.common.swagger;
import io.swagger.annotations.*;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import java.util.HashMap;
import java.util.Map;
@RestController
@Api(value = "SwaggerContollerV1")
@RequestMapping("/v1/api")
public class SwaggerContollerV1 {
@ApiOperation(value = "sample", notes = "테스트")
@ApiResponses({
@ApiResponse(code = 200, message = "ok"),
@ApiResponse(code = 500, message = "server error"),
@ApiResponse(code = 404, message = "not found"),
})
@GetMapping(value = "/test")
public Map<String, String> SwaggerTest(
@ApiParam(value = "번호", required = true, example = "1") @RequestParam String no) {
Map<String, String> result = new HashMap<>();
result.put("name", "otrodevym");
return result;
}
}
- @Api : Swagger 리소스 명시
- value : 태그를 작성
- @ApiOperation : API에 대한 간략한 설명
- @ApiResponse : operation의 가능한 response를 명시
- @ApiParam : 파라미터 정보 명시
반응형