Spring Boot/스프링 부트 핵심 가이드
[SpringBoot] 5.2 GET API 만들기
nayonsoso
2023. 7. 30. 20:55
Summary : GET API는 서버에서 값을 가져올 때 사용하고,
PathVariable과 ReqestParam을 이용해서 값을 넘겨줄 수 있다.
🔍 목차
5.2 GET API 만들기
5.2.1 @RequestMapping
5.2.2 매개변수가 없는 GET 메서드
5.2.3 @PathVariable을 이용하는 GET 메서드
5.2.4 @RequestParam을 이용하는 GET 메서드
5.2.5 DTO 객체를 이용하는 GET 메서드
📌 5.2 GET API 만들기
- GET API는 서버에서 값을 가져올 때 사용하는 API
- GET API를 작성하는 방법은 아래와 같다.
1. 매개변수 없이
2. @PathVariable
3. @RequestParam
📌 5.2.1 @RequestMapping
- @RequestMapping 어노테이션을 별다른 설정 없이 선언하면 HTTP의 모든 요청을 받는다.
- 따라서 GET 형식의 요청만 받기 위해서는 어노테이션에 별도 설정이 필요하다.
=> @RequestMapping(method = RequestMethod.GET) - 클래스 수준에서 @RequestMapping을 설정하면
클래스 내부에 선언한 메서드의 URL 리소스 앞에 @RequestMapping 의 값이 공통 값으로 추가된다. - 4.3 버전 이후로는 더 이상 @RequestMapping를 쓰지 않고,
더 명시적으로 HTTP method를 나타내주는 아래의 어노테이션을 사용한다.- @GetMapping
- @PostMapping
- @PutMapping
- @DeleteMapping
📌 5.2.2 매개변수가 없는 GET 메서드 구현
- 별도의 매개변수 없이 GET API를 구현하는 경우 아래와 같이 코드를 작성할 수 있다.
하지만 웹 통신의 기본 목적이 데이터를 주고받는 것이기 때문에 매개변수가 없는 GET 메서드는 거의 쓰이지 않는다.
@GetMapping(value = "/name") // 디폴트가 value이므로 value= 부분 생략 가능
public void getName() {
}
📌 5.2.3 @PathVariable을 활용한 GET 메서드 구현
- PathVarible은 URL에 값을 담아 전달하는 방법
- 값을 받아오기 위해서는 아래 원칙을 지켜야 한다.
1) URL에 중괄호 { }를 사용하여 받아올 변수의 위치와 이름을 표시
2) 컨트롤러 함수의 인자 부분에 @PathVariable을 명시하고, 변수 이름을 중괄호 내부와 통일
3) 이름을 통일하기 어렵다면, @PathVariable("중괄호 내부 이름") 으로 받아올 수도 있음
@GetMapping(value = "/variable1/{variable}")
public String getVariable1 (@PathVariable String variable) {
return variable;
}
@GetMapping(value="/variable2/{variable}")
public String getVariable2 (@PathVariable("variable") String var) {
return var;
}
📌 5.2.4 @RequestParam을 활용한 GET 메서드 구현
- RequestParam은 쿼리 스트링 형식으로 값을 전달하는 방법
- 쿼리 스트링 형식은 ?로 시작하고, 키와 값을 = 로 연결하고 복수의 키와 값은 &로 연결하는 형식
e.g ?id=9&name=yonso - 컨트롤러 메서드의 인자로 @RequestParam과 키와 일치하는 변수명을 사용하면 값을 받아올 수 있음
- 이름을 통일하기 어렵다면, @RequestParam("키이름") 으로 받아올 수도 있음
@GetMapping(value = "/request1")
public String getRequestParam1(@RequestParam String name) {
return "name: " + name;
}
@GetMapping(value = "/request2")
public String getRequestParam1(@RequestParam("name") String userName) {
return "user: " + userName;
}
💡cf. required와 defaultValue 옵션
- PathVariable과 RequestParam 모두 위와 같이 설정하고 형식에 맞게 입력하지 않으면 오류가 발생함
- 이를 막아주는 것이 Required와 Default 옵션
- cf. default가 아니라 defaultValue인 것 주의
@GetMapping(value = "/request1")
public String getRequestParam1(@RequestParam(required=false, defaultValue="yonso") String name) {
return "name: " + name;
}
📌 5.2.5 DTO 객체를 활용한 GET 메서드 구현
- DTO란, Data Transfer Object의 약자
- DTO는 Repository를 제외한 모든 레이어 간의 데이터 교환에 활용됨
- DTO에는 private 필드, Getter, Setter만 존재함
cf. DTO와 VO의 역할은 서로 엄밀하게 구분하지 않고 사용한다. - DTO의 필드는 쿼리 스트링의 키와 매핑됨
public String getRequestParam3 (MemberDto memberDto){
return memberDto.toString();
}