인프런 커뮤니티 질문&답변

1026baby님의 프로필 이미지
1026baby

작성한 질문수

[개정판 2023-11-27] Spring Boot 3.x 를 이용한 RESTful Web Services 개발

Spring 3.xx 이상이라면 SpringDoc 사용하세요

작성

·

493

·

수정됨

1

Spring 3 이상부터는 더 이상 Springfox가 아닌 SpringDoc으로 해야 Swagger 설정을 해줄 수 있습니다.

자세한 내용은 제가 참조한 아래 레퍼런스 확인해보시면 좋을 거 같아요

 

https://springdoc.org/

https://colabear754.tistory.com/99

https://velog.io/@kjgi73k/Springboot3%EC%97%90-Swagger3%EC%A0%81%EC%9A%A9%ED%95%98%EA%B8%B0

 

아래는 참고하여 작성한 코드입니다.

 


@Configuration
public class SwaggerConfig {
    @Bean
    public OpenAPI openAPI(){
        return new OpenAPI()
                .components(new Components())
                .info(apiInfo());
    }

    private Info apiInfo() {
        return new Info()
                .title("Springdoc 테스트")
                .description("Springdoc을 사용한 Swagger UI 테스트")
                .version("1.0.0");
    }
}

 

 

@RestController
@RequestMapping("/swagger")
public class SwaggerController {
    @Operation(summary = "문자열 반복", description = "파라미터로 받은 문자열을 2번 반복합니다.")
    @Parameter(name = "str", description = "2번 반복할 문자열")
    @GetMapping("/returnStr")
    public String returnStr(@RequestParam String str) {
        return str + "\n" + str;
    }

    @GetMapping("/example")
    public String example() {
        return "예시 API";
    }

    @Hidden
    @GetMapping("/ignore")
    public String ignore() {
        return "무시되는 API";
    }
}

 

NOTE:

springdoc.swagger-ui.path에서 swagger url 기본 경로를 설정합니다. 저는 아래와 같이 /swagger로 접속하게끔 했습니다.

# SPRINGDOC
springdoc.packages-to-scan=com.example.dateanu.rest_api
springdoc.default-consumes-media-type= application/json;charset=UTF-8
springdoc.default-produces-media-type= application/json;charset=UTF-8
springdoc.swagger-ui.path=/swagger
springdoc.swagger-ui.disable-swagger-default-url=true
springdoc.swagger-ui.display-request-duration=true
springdoc.swagger-ui.operations-sorter=alpha

 

 

답변 1

0

안녕하세요, 인프런 AI 인턴이에요.

Spring 3 이상부터는 Springfox 대신 SpringDoc을 사용하여 Swagger 설정을 해주셔야 합니다. 참조한 레퍼런스와 작성한 코드를 통해 Swagger 설정을 할 수 있습니다.

SwaggerConfig 클래스에서는 @Configuration 어노테이션을 추가하고, @Bean 어노테이션을 사용하여 openAPI 빈을 생성합니다. 그리고 OpenAPI 객체를 반환하며, Components 객체와 apiInfo() 메서드를 사용하여 Swagger 설정을 추가합니다.

apiInfo() 메서드에서는 Info 객체를 반환하며, title, description, version 등의 정보를 설정할 수 있습니다.

SwaggerController 클래스에서는 @RestController 어노테이션과 @RequestMapping 어노테이션을 사용하여 요청 경로를 설정합니다. @Operation 어노테이션과 @Parameter 어노테이션을 사용하여 API에 대한 설명과 파라미터 정보를 추가할 수 있습니다.

위의 코드를 통해 문자열을 반복하는 API와 예시 API를 구현할 수 있습니다.

궁금한 점이 있으시면 더 자세히 알려주세요.

1026baby님의 프로필 이미지
1026baby

작성한 질문수

질문하기