본문 바로가기
백엔드 공부/HTTP 기본 지식

HTTP 메서드 활용 : HTTP 기본 지식

by CSEGR 2024. 2. 28.
728x90

(인프런) 김영한님의 모든 개발자를 위한 HTTP 웹 기본 지식을 공부하고 리뷰한 글입니다.

클라이언트에서 서버로 데이터 전송 
클라이언트에서 서버로 데이터 전송 

1. query 파라미터를 통한 데이터 전송 

   - 주로 GET일 때 사용  

   - 주로 정렬 필터(검색어)

2. 메시지 바디를 통한 데이터 전송 

   - POST, PUT, PATCH

   - 회원 가입, 상품 주문, 리소스 등록, 리소스 변경 

 

<클라이언트에서 서버로 데이터 전송하는 4가지 상황>

1. 정적 데이터 조회 

   - 이미지, 정적 텍스트 문서

   - 조회는 GET 사용 

   - 정적 데이터는 일반적으로 query 파라미터 없이 리소스 경로로 단순하게 조회 가능  

- > 추가 적인 데이터 필요 없음. 

2. 동적 데이터 조회 

 - 주로 검색, 게시판 목록에서 정렬 필터(검색어)

 - 조회 조건을 줄여주는 필터, 조회 결과를 정렬하는 정렬 조건에 주로 사용 

 - GET 은 쿼리 파라미터 사용해서 데이터를 전달 

  3. HTML Form 을 통한 데이터 전송 

    - 회원 가입, 상품 주문, 데이터 변경

데이터가 쿼리 파라미터와 동일한 방식으로 HTTP 메시지 바디에 넣어서 보냄 .

method가 get인 경우 http 메시지 바디에 넣는 것이아니라 url 경로에다가 쿼리 파라미터 형태로 넣음 . 

 

4. HTTP API를 통한 데이터 전송 

    - 회원 가입, 상품 주문, 데이터 변경 

    - 서버 to 서버, 앱 클라이언트, 웹 클라이언트 (Ajax)

 - HTML, Form 전송은 GET, POST만 지원

 - 앱 클라이언트 ( 아이폰, 안드로이드) 

 - 웹 클라이언트  ( HTML 에서 Form 전송 대신 자바 스크립트를 통한 통신에 사용 ) 

 - 서버 to 서버 : 백엔드 시스템 통신 

 - POST, PUT, PATCH : 메세지 바디를 통해 데이터 전송 

 - GET : 조회, query 파라미터로 데이터 전달 

 - Content-Type : application/json 을 주로 사용 (TEXT, XML, JSON 등등) 

 

 

 

HTTP API 설계 예시

 

- HTTP API : 컬렉션 

   - POST 기반 등록 ex) 회원 관리 API 제공

- HTTP API : 스토어 

    - PUT 기반 등록 ex) 정적 컨텐츠 관리, 원격 파일 관리 

- HTTP FORM 사용 

    - 웹 페이지 회원 관리 

    - GET , POST 만 지원

 

<회원 관리 시스템 >

POST - 신규 자원 등록 특징 

- 클라이언트는 등록될 리소스의 URI를 모른다. 

   -회원 등록/ members -> POST

   - POST/members

- 서버가 새로 등록된 리소스 URI를 생성해준다. 

   - HTTP/1.1 201 Created

      Location: /members/100

- 컬렉션(Collection)

    - 서버가 관리하는 리소스 디렉토리 

    - 서버가 리소스의 URI를 생성하고 관리 

    - ex) /members

 

PUT 

- 클라이언트가 리소스 URI를 알고 있어야한다. 

   -PUT /files/star.jpg

- 클라이언트가 직접 리소스의 URI 를 지정한다. 

- 스토어(Store)

    - 클라이언트가 관리하는 리소스 저장소 

    - 클라이언트가 리소스의 URI를 알고 관리 

    - ex)  /files 

 

HTML FORM 사용 

- HTML FORM은 GET, POST만 지원

-> 제약이 있으므로 컨트롤 URI 사용

    - POST의 /new, /edit, /delete가 컨트롤 URI 

    - HTTP 메서드로 해결하기 애매한 경우 사용 (HTTP API 포함) 

 

컨트롤러 (controller), 컨트롤 URI

   - 문서, 컬렉션, 스토어로 해결하기 어려운 추가 프로세스 실행

   - 동사를 직접 사용 (/new , /edit, /delete)

   - ex) /members/{id}/delete

728x90