inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

634

1026baby

작성한 질문수 4

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

 

 

rest-api spring-boot swagger springdoc springfox

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 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를 구현할 수 있습니다.

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

JPA

0

60

1

jpa dependency를 추가하고 SecurityConfig클래스에서 오류가 납니다.

0

70

1

웹 브라우저 400 bad request

0

73

1

@Size는 되는데 @Past는 안 됩니다.

0

62

1

pdf 자료는 없나요?

0

75

2

locale 정보가 null 이면 무조건 messages_ko.properties이 호출 되는 문제

0

89

2

Swagger 강의, Unable to infer base url 이거 뜨시는 분들 도움되시라고

0

119

1

강의에서나온 화면 피피티

0

160

1

HelloWorldBean 관련 에러

0

185

2

Swagger API 3.x 오류..

0

221

1

java: variable message not initialized in the default constructor 에러는 어찌하면 좋을까요?

1

283

1

현재 GIT에 올리신 소스를 실행해봤습니다.

0

189

2

고양이 소리가 귀엽네요 !!

0

138

2

git에서 소스받고 실습중인데

0

118

1

post가 안되요

0

105

1

한국어 같은 경우 언어코드인 messages_ko.properties 로 생성하는게 더 좋지 않나요?

0

169

2

리턴타입으로서 EntityModel<User> 와 ResponseEntity질문

0

105

1

예외처리쪽 관련 질문있습니다.

0

160

2

엔티티가 바로 응답으로 나가도 되나요??

0

223

2

안녕하세여 Cannot invoke "co.kr.joneconsulting.resfulservice.repository.PostRepository.save(Object)" because "this.postRepository" is null

0

138

2

사용자 등록하고 나서 H2 에서 보면 신규 사용자의 password, ssn 이 null 로 되어 있습니다.

0

141

2

ApplictionContext 질문

0

195

2

롬북이 안먹히는것같아요

0

158

1

인텔리제이에서스프링부트 파일 실행하면

0

241

1