웹 기본 지식 정리(2)

YulHee Kim·2021년 9월 2일
0

웹 지식

목록 보기
2/4

[참고 강의] 김영한님의
모든 개발자를 위한 HTTP 웹 기본 지식

💡 HTTP 메서드 활용

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

  • 쿼리 파라미터를 통한 데이터 전송
    • 주로 정렬 필터(검색어)
    • GET
  • 메시지 바디를 통한 데이터 전송
    • 회원 가입, 상품 주문, 리소스 등록, 리소스 변경
    • POST, PUT, PATCH

4가지 상황

  • 정적 데이터 조회
    • 이미지, 정적 텍스트 문서
  • 동적 데이터 조회
    • 주로 검색, 게시판 목록에서 정렬 필터(검색어)
  • HTML Form을 통한 데이터 전송
    • 회원 가입, 상품 주문, 데이터 변경
  • HTTP API를 통한 데이터 전송
    • 회원 가입, 상품 주문, 데이터 변경
    • 서버 to 서버, 앱 클라이언트, 웹 클라이언트(Ajax)

✏️ HTTP API 데이터 전송

정리

  • 서버 to 서버
    • 백엔드 시스템 통신
  • 앱 클라이언트
    • 아이폰, 안드로이드
  • 웹 클라이언트
    • HTML에서 Form 전송 대신 자바 스크립트를 통한 통신에 사용(AJAX)
    • 예) React, VueJs 같은 웹 클라이언트와 API통신
  • POST, PUT, PATCH : 메시지 바디를 통해 데이터 전송
  • GET : 조회, 쿼리 파라미터로 데이터 전달
  • Content-Type : application/json을 주로 사용
    • TEXT, XML,JSON 등등

참고하면 좋은 URI 설계 개념

  • 문서
    • 단일 개념(파일 하나, 객체 인스턴스, 데이터베이스 row)
    • /members/100, /files/star.jpg
  • 컬렉션
    • 서버가 관리하는 리소스 디렉터리
    • 서버가 리소스의 URI를 생성하고 관리
    • 예) /members
  • 스토어(store)
    • 클라이언트가 관리하는 자원 저장소
    • 클라이언트가 리소스이 URI를 알고 관리
    • 예) /files
  • 컨트롤러, 컨트롤 URI
    • 문서, 컬렉션, 스토어로 해결하기 어려운 추가 프로세스 실행
    • 동사를 직접 사용
    • 예) /members/{id}/delete

✏️ HTTP 상태코드

클라이언트가 보낸 요청의 처리 상태를 응답에서 알려주는 기능

  • 1xx : 요청이 수신되어 처리중
  • 2xx : 요청 정상 처리
  • 3xx : 요청을 완료하려면 추가 행동이 필요
  • 4xx : 클라이언트 오류, 잘못된 문법등으로 서버가 요청을 수행할 수 없음
  • 5xx : 서버 오류, 서버가 정상 요청을 처리하지 못함

✏️ 리다이렉션 이해

  • 영구 리다이렉션 : 특정 리소스의 URI가 영구적으로 이동
    • 예) /members -> /users
    • 예) /event -> /new-event
  • 일시 리다이렉션 : 일시적인 변경
  • 특수 리다이렉션 : 결과 대신 캐시를 사용

💡 HTTP 헤더

용도

  • HTTP 전송에 필요한 모든 부가 정보
  • 예) 메시지 바디의 내용, 메시지 바디의 크기, 압축, 인증, 요청 클라이언트, 서버 정보, 캐시 관리 정보...
  • 표준 헤더가 너무 많음
  • 필요시 임의의 헤더 추가 가능

헤더 분류

  • General 헤더: 메시지 전체에 적용되는 정보, 예) Connection: close
  • Request 헤더: 요청 정보
  • Response 헤더 : 응답 정보
  • Entity 헤더 : 엔티티 바디 정보

HTTP BODY

  • 메시지 본문(message body)을 통해 표현 데이터 전달
  • 메시지 본문 = 페이로드
  • 표현은 요청이나 응답에서 전달할 실제 데이터
  • 표현 헤더는 표현 데이터를 해석할 수 있는 정보 제공
    • 데이터 유형(html, json), 데이터 길이, 압축 정보 등등
  • 참고 : 표현 헤더는 표현 메타데이터와, 페이로드 메시지를 구분해야하 하지만 여기서는 생략

으어어어아아아아ㅏㅏㅏㅏ

profile
백엔드 개발자

0개의 댓글