Spring Boot Swagger 3.x 적용
1. Swagger 란?
Swagger 는 OAS(Open Api Specification)를 위한 프레임워크입니다.
개발자들의 필수 과제인 API 문서화를 쉽게 할 수 있도록 도와주며, 파라미터를 넣어서 실제로 어떤 응답이 오는지 테스트도 할 수 있습니다.
또한, 협업하는 클라이언트 개발자들에게도 Swagger 만 전달해주면 API Path 와 Request, Response 값 및 제약 등을 한번에 알려줄 수 있습니다.
1.1. OpenAPI 와의 관계
Swagger 공식 블로그 포스팅을 보면 Swagger 와 OpenAPI 의 차이가 나와있습니다.
OpenAPI는 RESTful API 설계를 위한 업계 표준 사양을 나타내고 Swagger는 SmartBear 도구 세트를 나타냅니다
요약하면 Swagger 는 이제 OpenAPI 사양을 구현하기 위한 도구 세트 (Swagger Editor, Swagger UI, SwaggerHub) 가 되었으며, 브랜드명만 변경하지 않은 채 그대로 사용하기로 했습니다.
2. 적용
Swagger 2.x 버전을 적용할 수도 있고 3.x 버전을 적용할 수도 있습니다.
큰 차이는 없기 때문에 최신 버전인 Swagger 3.x 버전을 적용합니다.
2.1. 의존성 추가
/* build.gradle */
dependencies {
// ..
implementation 'io.springfox:springfox-boot-starter:3.0.0'
// ..
}
- 사용할 버전은 https://mvnrepository.com/artifact/io.springfox/springfox-boot-starter 여기에서 확인 할 수 있습니다.
- Swagger 2.x 버전과 다르게
springfox-boot-starter
하나만 추가하면 하위에 필요한 모든 라이브러리가 포함되어 있습니다.
2.2. Config 추가
@Configuration
public class SwaggerConfig {
@Bean
public Docket api() {
return new Docket(DocumentationType.OAS_30)
.useDefaultResponseMessages(false)
.select()
.apis(RequestHandlerSelectors.basePackage("com.example.springswagger.controller"))
.paths(PathSelectors.any())
.build()
.apiInfo(apiInfo());
}
private ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title("Practice Swagger")
.description("practice swagger config")
.version("1.0")
.build();
}
}
Docket
: Swagger 설정의 핵심이 되는 BeanuseDefaultResponseMessages
: Swagger 에서 제공해주는 기본 응답 코드 (200, 401, 403, 404).false
로 설정하면 기본 응답 코드를 노출하지 않음apis
: api 스펙이 작성되어 있는 패키지 (Controller) 를 지정paths
:apis
에 있는 API 중 특정 path 를 선택apiInfo
:Swagger UI 로 노출할 정보
2.3. Controller 에 적용
@RestController
public class HelloController {
@Operation(summary = "test hello", description = "hello api example")
@ApiResponses({
@ApiResponse(responseCode = "200", description = "OK !!"),
@ApiResponse(responseCode = "400", description = "BAD REQUEST !!"),
@ApiResponse(responseCode = "404", description = "NOT FOUND !!"),
@ApiResponse(responseCode = "500", description = "INTERNAL SERVER ERROR !!")
})
@GetMapping("/hello")
public ResponseEntity<String> hello(@Parameter(description = "이름", required = true, example = "Park") @RequestParam String name) {
return ResponseEntity.ok("hello " + name);
}
}
- 적용한 설정들이 어떻게 표현되는지는 아래에서 설명합니다.
2.4. 실행 후 접속
로컬 실행 후 URL 접속하면 되는데 Swagger 2.x 버전과 조금 다릅니다.
- Swagger2: http://localhost:8080/swagger-ui.html
- Swagger3: http://localhost:8080/swagger-ui/index.html
3. 적용된 설정 확인
SwaggerConfig
에서 설정한 정보들은 Swagger 상단에 나옵니다.
Controller
에서 세팅한 설정입니다.
4. SpringDoc ?
Swagger 는 SpringFox 외에 SpringDoc 으로도 설정할 수 있습니다.
특히 현재 Spring Boot 2.6 버전에서 SpringFox Swagger 3.0 의 사용하지 못하는 이슈가 존재합니다.
이럴 때 SpringDoc 공식 문서 를 참고하면 Spring Boot 를 2.5 버전대로 내리지 않아도 Swagger 를 적용할 수 있습니다.