[꼼꼼한 개발자] 꼼코더
13. 모든 개발자를 위한 HTTP 웹 기본 지식 - [HTTP 메서드] - GET, POST 본문
반응형
📑 HTTP 메서드 종류
- GET : 리소스를 조회
- POST : 요청 데이터를 담아서 처리
- PUT : 리소스를 대체 *해당 리소스가 없으면 생성
- PATCH : 리소스 부분 변경
- DELETE : 리소스 삭제
- HEAD : GET과 동일하지만 메시지 부분을 제외하고 상태 줄과 헤더만 반환
- OPTIONS : 대상 리소스에 대한 통신 가능 옵션(메서드)를 설명 (주로 CORS에서 사용)
- TRACE : 대상 리소스에 대한 경로를 따라 메시지 루프백 테스트를 수행
GET과 POST는 클라이언트가 서버에 뭔가 요청을 할 때 기대하는 행동이다.
🔎 GET
- 리소스를 조회한다.
- 서버에 전달하고 싶은 데이터는 쿼리 파라미터 또는 쿼리 스트링을 통해서 전달한다.
- GET은 메시지 바디를 전달할 수 있지만 실무에서는 바디에 보통 데이터를 넣지 않는다.
- 지원하지 않는 서버들이 많아서 권장하지 않는다.
🧑🏻🏫 GET 과정
1) 리소스 조회1 - 메시지 전달
- 클라이언트가 members/100 유저를 조회하기 위해 GET 방식으로 HTTP 요청 메시지를 서버에 전달한다.
2) 리소스 조회2 - 서버 도착
- 서버에 GET 메시지가 도착하면 서버는 GET 메시지를 해석하여 DB에서 /members/100 유저를 조회하여 JSON 메시지를 만든다.
3) 리소스 조회3 - 응답 데이터
- 서버는 리소스 조회에 성공했다는 의미
- status-line에는 200 OK,
- header에는 Content-Type
- message-body에는 /members/100을 조회한 결과(JSON)를 붙여 HTTP 응답 메시지를 만든다.
👨🏻💻 POST
- 요청 데이터를 담아서 처리한다.
- 클라이언트에서 메시지 바디를 통해 서버로 요청해서 서버가 데이터를 처리하는 모든 기능을 수행한다.
- 주로 전달된 데이터로 신규 리소스 등록하거나 변경된 프로세스를 바꿀 때 많이 이용한다.
👨🏻🏫 POST 과정
1) 리소스 조회1 - 메시지 전달
- 클라이언트가 유저를 등록하기 위해 message-body에 유저 데이터를 담아서 POST 방식으로 HTTP 요청 메시지를 서버에 전달한다.
- (POST로 /members에 요청이 들어오면 서버는 데이터를 저장한다는 것을 미리 약속해놓는다)
2) 리소스 조회2 - 서버 도착
- 서버에 POST 메시지가 도착하면 서버는 POST 메시지를 해석하여 DB에 데이터를 등록하고 신규 리소스 식별자를 생성한다.
3) 리소스 조회3 - 응답 데이터
- 서버는 데이터 등록을 성공했다는 의미로
- status-line에는 201 Created,
- header에는 Location(리소스가 생성된 신규 URI 경로(/members/100)
- message-body에는 **등록된 리소스(JSON)**을 붙여 HTTP 응답 메시지를 만든다.
👀 POST 예시, 요청 데이터를 어떻게 처리한다는 뜻일까?
스펙 : POST 메서드는 대상 리소스가 리소스의 고유한 의미 체계에 따라 요청에 포함된 표현을 처리하도록 요청한다.
- HTML 양식에 입력된 필드와 같은 데이터 블록을 데이터 처리 프로세스에 제공
- HTML 폼에 입력한 정보로 회원가입하거나 주문 문 등을 처리
- 게시판, 뉴스 그룹, 메일링 리스트, 블로그 또는 유사한 기사 그룹에 메시지 게시
- 게시판에 글쓰거나 댓글 달기
- 게시판에 글을 쓰고 Submit 누르면 POST로 글이 서버로 전달하고 서버가 게시판에 글을 저장한다.
- 서버가 아직 식별하지 않은 새 리소스 생성
- 신규 주문을 생성하거나 신규 회원을 생성할 때
- 기존 자원의 끝에 데이터를 추가
- 한 문서 끝에 내용 추가하기
→ 이 리소스 URI에 POST 요청이 오면 요청 데이터를 어떻게 처리할지 리소스마다 따로 정해야 함(정해진 것이 없음)
- 한 문서 끝에 내용 추가하기
🧹 POST 정리
- 새 리소스 생성(등록)
- 서버가 아직 식별하지 않은 새 리소스 생성(주로 이 목적으로 많이 사용)
- 요청 데이터 처리(중요)
- 단순히 데이터를 생성, 변경하는 것을 넘어서 프로세스를 처리해야하는 경우
- → 주문에서 결제완료 ➡️ 배달 시작 ➡️ 배달완료 처럼 단순히 값 변경을 넘어 프로세스의 상태가 변경되는 경우
- 기본적으로 리소스만을 가지고 URI를 설계하는 것이 이상적이지만, 실무에서는 어쩔 수 없이 리소스만으로 URI 설계 안 될 경우컨트롤 URI로 설계한다. (start-delivery 처럼 동사가 어쩔 수 없이 들어갈 수 있음)
- → 컨트롤 URI : POST /orders/{orderld}/start-delivery
- 다른 메서드로 처리하기 애매한 경우
- JSON으로 조회 데이터를 넘겨야 하는데 GET 메서드를 지원하지 않는 서버가 있어서 사용하기 어려운 경우 POST의 message-body에 조회 데이터를 넘긴다.
- 애매하면 POST 사용하면 좋다.
🙋🏻♂️ Q&A
Q. /orders/{orderId}/start-delivery 는 배달 상태 변경의 의미에서 POST가 아닌 PATCH를 사용해야하는 거 아닌가?
A. 배달 상태를 변경한다는 것은 단순히 해당 리소스의 값을 변경하는 정도로 끝나는 것이 아니라, 내부에서 매우 큰 프로세스가 실행된다.
이렇게 해당 리소스만 변경하는 것이 아니라 내부 프로세스를 실행해야할 때는 PATCH보다 POST를 사용하는 것이 좋다. 단순히 회원 정보를 변경하는 것처럼 특정 리소스의 데이터를 변경할 때는 PATCH를 사용하는 것이 좋다.
(참고)
[출처] https://www.inflearn.com/questions/110170
Q. GET 메서드를 사용해 복수 개의 리소스를 조회할 때, URI를 어떤식으로 설계하는 것이 좋을까?
A. 예를 들어, id가 3, 4, 5인 회원을 조회하고 싶다면 path를 사용하기보다는 query string을 사용하는 것이 더 좋다.
[출처] https://www.inflearn.com/questions/212054
참고 : https://hseungyeon.tistory.com
위 자료는 김영한님의 ‘모든 개발자를 위한 HTTP 웹 기본 지식’ 강의를 참고하여 작성하였습니다.
https://www.inflearn.com/course/http-웹-네트워크/dashboard
'HTTP' 카테고리의 다른 글
15. 모든 개발자를 위한 HTTP 웹 기본 지식 - [HTTP 메서드] - HTTP 메서드의 속성 (0) | 2022.11.15 |
---|---|
14. 모든 개발자를 위한 HTTP 웹 기본 지식 - [HTTP 메서드] - PUT, PATCH, DELETE (0) | 2022.11.15 |
12. 모든 개발자를 위한 HTTP 웹 기본 지식 - [HTTP 메서드] - HTTP API를 만들어보자 (0) | 2022.11.08 |
11. 모든 개발자를 위한 HTTP 웹 기본 지식 - [HTTP 기본] - HTTP 메세지 (0) | 2022.11.08 |
10. 모든 개발자를 위한 HTTP 웹 기본 지식 - [HTTP 기본] - 비 연결성(connectionless) (0) | 2022.11.08 |
Comments