HTTP 메서드 활용
클라이언트에서 서버로 데이터 전송
- 쿼리 파라미터를 통한 데이터 전송 (폼을 이용하여 전송해도 가능)
- GET
- 주로 정렬 필터(검색어)
- 메시지 바디를 통한 데이터 전송
- POST, PUT, PATCH
- 회원 가입, 상품 주문, 리소스 등록, 리소스 변경
4가지 상황
- 정적 데이터 조회
- 이미지, 정적 텍스트 문서
- 조회는 GET 사용
- 정적 데이터는 일반적으로 쿼리 파라미터 없이 리소스 경로로 단순하게 조회 가능
- 동적 데이터 조회
- 주로 검색, 게시판 목록에서 정렬 필터 (검색어)
- 조회 조건을 줄여주는 필터, 조회 결과를 정렬하는 정렬 조건에 주로 사용
- 조회는 GET 사용
- GET은 쿼리 파라미터 사용해서 데이터를 전달
- HTML Form 데이터 전송
- GET 전송은 쿼리파라미터 형식으로 전송하고, 저장하는데 쓰면 안된다.
- GET, POST만 지원 (PUT, DELETE 안됨)
- multipart/form-data : 경계를 잘라줘서 여러 컨텐츠 타입을 보낼 수 있다.
- 주로 파일 업로드 같은 바이너리 데이터를 보낼 때 사용한다.
- 데이터에 한글이 포함되어 있을 시 url encoding 처리를 하여 넘겨준다.
- HTTP API
- 서버끼리 통신할 때, 앱 클라이언트, 웹 클라이언트(Ajax)
- 폼 데이터를 사용하지 않을 때 회원가입, 주문, 데이터 변경
- Content-Type으로는 주로 application/json을 사용한다.
HTTP API 설계 예시
- HTTP API - 컬렉션
- POST 기반 등록
- POST로 만들 땐 서버에서 리소스 URI를 만들어 준다.
- 컬렉션 : 서버가 관리하는 리소스 디렉토리, 서버가 리소스의 URI를 생성하고 관리. 예를들어 컬렉션은 /members 이다.
- HTTP API - 스토어
- PUT - 신규 자원 등록 특징
- 클라이언트가 리소스의 URI를 알고 있어야 한다.
- 스토어(Store) : 클라이언트가 관리하는 리소스 저장소. 예를들어 스토어는 /files 이다.
- HTML Form 사용
- GET, POST만 지원하므로 DELETE 같은 경우 컨트롤 URI를 이용하여 표현해야한다.
- 예를 들어 /new, /edit, /delete 등으로 컨트롤 URI를 표현한다.
- HTTP 메서드로 해결하기 애매한 경우 사용 (HTTP API 포함)
'HTTP' 카테고리의 다른 글
HTTP 헤더 - 일반 헤더 (2) | 2024.09.20 |
---|---|
HTTP 상태코드 (0) | 2024.09.12 |
HTTP 메서드 (0) | 2024.09.09 |
HTTP 기본 (3) | 2024.09.04 |
웹 브라우저 요청 흐름 (0) | 2024.05.15 |