1. Project Test
- spring initalizr / swagger / web, lombok / swagger은 maven repository에서 따로 확인하여 설치
01. Swagger 설치
data:image/s3,"s3://crabby-images/e5e10/e5e10ee9874d005c3d0aef0d883fccf6c4907e11" alt=""
// https://mvnrepository.com/artifact/io.springfox/springfox-boot-starter
implementation group: 'io.springfox', name: 'springfox-boot-starter', version: '3.0.0'
data:image/s3,"s3://crabby-images/f4e58/f4e584a67a49e5efc3e85763fb174a0a96c9c811" alt=""
02. Talent API 대신 Swagger UI 사용
-1. 일단 간단 테스트
- Package : controller
- Class : ApiController
- controller / ApiController.java
package com.example.swagger.controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("/api")
public class ApiController {
@GetMapping("/hello")
public String hello() {
return "hello";
}
}
-2. Swagger UI의 api controller 수정해보기
_1. Class의 리소스 변경
- ApiController.java
- @Api(tags = {"API 정보를 제공하는 Controller"})
- @Api, 클래스를 스웨거의 리소스로 표시
- tags를 통해서 리소스 명 지정
package com.example.swagger.controller;
import io.swagger.annotations.Api;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
// @Api, 클래스를 스웨거의 리소스로 표시
@Api(tags = {"API 정보를 제공하는 Controller"})
@RestController
@RequestMapping("/api")
public class ApiController {
@GetMapping("/hello")
public String hello() {
return "hello";
}
}
data:image/s3,"s3://crabby-images/893d0/893d010a0cd75db2b223e9d31bba319f3e027cb1" alt=""
_2. 오퍼레이션(Method) Parameter 메타 데이터 설정
- ApiController.java
- @ApiParam(value = "x값")
- @ApiParam은 오퍼레이션 파라미터의 메타 데이터 지정
- value로 지정
package com.example.swagger.controller;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiParam;
import org.springframework.web.bind.annotation.*;
@Api(tags = {"API 정보를 제공하는 Controller"})
@RestController
@RequestMapping("/api")
public class ApiController {
@GetMapping("/hello")
public String hello() {
return "hello";
}
@GetMapping("/plus/{x}")
public int plus(
@ApiParam(value = "x값")
@PathVariable int x,
@ApiParam(value = "y값")
@RequestParam int y
) {
return x + y;
}
}
data:image/s3,"s3://crabby-images/bfab6/bfab69cc553bccebdc857d47c5356248a8c67b24" alt=""
_3. Model의 속성 데이터 설정
- Package : dto
- Class : UserReq, UserRes
- dto / UserReq.java
- @ApiModelProperty(value = "사용자의 이름", example = "steve", required = true)
package com.example.swagger.dto;
import io.swagger.annotations.ApiModelProperty;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@NoArgsConstructor
@AllArgsConstructor
public class UserReq {
@ApiModelProperty(value = "사용자의 이름", example = "steve", required = true)
private String name;
@ApiModelProperty(value = "사용자의 나이", example = "20", required = true)
private int age;
}
package com.example.swagger.dto;
import io.swagger.annotations.ApiModelProperty;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@NoArgsConstructor
@AllArgsConstructor
public class UserRes {
@ApiModelProperty(value = "사용자의 이름", example = "steve", required = true)
private String name;
@ApiModelProperty(value = "사용자의 나이", example = "20", required = true)
private int age;
}
- controller / ApiController.java
package com.example.swagger.controller;
import com.example.swagger.dto.UserReq;
import com.example.swagger.dto.UserRes;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiParam;
import org.springframework.web.bind.annotation.*;
@Api(tags = {"API 정보를 제공하는 Controller"})
@RestController
@RequestMapping("/api")
public class ApiController {
@GetMapping("/hello")
public String hello() {
return "hello";
}
@GetMapping("/plus/{x}")
public int plus(
@ApiParam(value = "x값")
@PathVariable int x,
@ApiParam(value = "y값")
@RequestParam int y
) {
return x + y;
}
@GetMapping("/user")
public UserRes user(UserReq userReq) {
return new UserRes(userReq.getName(), userReq.getAge());
}
}
data:image/s3,"s3://crabby-images/ad729/ad72913b430247e4e28bb8f92d518460017cf6ed" alt=""
_4. 특정 경로의 오퍼레이션 HTTP 메소드 설명 추가
- controller / ApiController.java
- @ApiOperation(value = "사용자의 이름과 나이를 리턴하는 메소드")
- 특정 경로의 오퍼레이션 HTTP 메소드 설명 추가
package com.example.swagger.controller;
import com.example.swagger.dto.UserReq;
import com.example.swagger.dto.UserRes;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import org.springframework.web.bind.annotation.*;
@Api(tags = {"API 정보를 제공하는 Controller"})
@RestController
@RequestMapping("/api")
public class ApiController {
@GetMapping("/hello")
public String hello() {
return "hello";
}
@GetMapping("/plus/{x}")
public int plus(
@ApiParam(value = "x값")
@PathVariable int x,
@ApiParam(value = "y값")
@RequestParam int y
) {
return x + y;
}
@ApiOperation(value = "사용자의 이름과 나이를 리턴하는 메소드")
@GetMapping("/user")
public UserRes user(UserReq userReq) {
return new UserRes(userReq.getName(), userReq.getAge());
}
}
data:image/s3,"s3://crabby-images/bc2bc/bc2bcb7ef2137a32a957213c9400cd300cea9f15" alt=""
_5. 오퍼레이션 응답지정(code, error 등)
- controller / ApiController.java
- @ApiResponse(code = 502, message = "사용자의 나이가 10살 이하일때")
- 오퍼레이션 응답지정(code, error 등)
package com.example.swagger.controller;
import com.example.swagger.dto.UserReq;
import com.example.swagger.dto.UserRes;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import io.swagger.annotations.ApiResponse;
import org.springframework.web.bind.annotation.*;
@Api(tags = {"API 정보를 제공하는 Controller"})
@RestController
@RequestMapping("/api")
public class ApiController {
@GetMapping("/hello")
public String hello() {
return "hello";
}
@GetMapping("/plus/{x}")
public int plus(
@ApiParam(value = "x값")
@PathVariable int x,
@ApiParam(value = "y값")
@RequestParam int y
) {
return x + y;
}
@ApiResponse(code = 502, message = "사용자의 나이가 10살 이하일때")
@ApiOperation(value = "사용자의 이름과 나이를 리턴하는 메소드")
@GetMapping("/user")
public UserRes user(UserReq userReq) {
return new UserRes(userReq.getName(), userReq.getAge());
}
}
data:image/s3,"s3://crabby-images/66a8e/66a8e35f2af2dd2babcd1984139e199ee25715e9" alt=""
_6. POST 비교
- controller / ApiController.java
- 모델 설정을 그대로 갖고 오는 점을 보와 위와 동일하게 사용
package com.example.swagger.controller;
import com.example.swagger.dto.UserReq;
import com.example.swagger.dto.UserRes;
import io.swagger.annotations.*;
import org.springframework.web.bind.annotation.*;
@Api(tags = {"API 정보를 제공하는 Controller"})
@RestController
@RequestMapping("/api")
public class ApiController {
@GetMapping("/hello")
public String hello() {
return "hello";
}
@ApiImplicitParams({
@ApiImplicitParam(name = "x", value = "x 값", required = true, dataType = "int", paramType = "path"),
@ApiImplicitParam(name = "y", value = "y 값", required = true, dataType = "int", paramType = "query")
})
@GetMapping("/plus/{x}")
public int plus(@PathVariable int x,@RequestParam int y) {
return x + y;
}
@ApiResponse(code = 502, message = "사용자의 나이가 10살 이하일때")
@ApiOperation(value = "사용자의 이름과 나이를 리턴하는 메소드")
@GetMapping("/user")
public UserRes user(UserReq userReq) {
return new UserRes(userReq.getName(), userReq.getAge());
}
@PostMapping("/user")
public UserRes userPost(@RequestBody UserReq userReq) {
return new UserRes(userReq.getName(), userReq.getAge());
}
}
data:image/s3,"s3://crabby-images/d33d4/d33d43438470bb2afd64f448f9f3a76f8579392d" alt=""
_7. @ApiParam을 @ApiImplicitParams으로 변경
- controller / ApiController.java
- @ApiImplicitParams & @ApiImplicitParam
package com.example.swagger.controller;
import com.example.swagger.dto.UserReq;
import com.example.swagger.dto.UserRes;
import io.swagger.annotations.*;
import org.springframework.web.bind.annotation.*;
@Api(tags = {"API 정보를 제공하는 Controller"})
@RestController
@RequestMapping("/api")
public class ApiController {
@GetMapping("/hello")
public String hello() {
return "hello";
}
@ApiImplicitParams({
@ApiImplicitParam(name = "x", value = "x 값", required = true, dataType = "int", paramType = "path"),
@ApiImplicitParam(name = "y", value = "y 값", required = true, dataType = "int", paramType = "query")
})
@GetMapping("/plus/{x}")
public int plus(@PathVariable int x,@RequestParam int y) {
return x + y;
}
@ApiResponse(code = 502, message = "사용자의 나이가 10살 이하일때")
@ApiOperation(value = "사용자의 이름과 나이를 리턴하는 메소드")
@GetMapping("/user")
public UserRes user(UserReq userReq) {
return new UserRes(userReq.getName(), userReq.getAge());
}
@PostMapping("/user")
public UserRes userPost(@RequestBody UserReq userReq) {
return new UserRes(userReq.getName(), userReq.getAge());
}
}