본문 바로가기
스파르타 내일배움캠프/TIL(Today I learned)

25.03.25 TIL - HTTP(2)

by pandastic 2025. 3. 25.
반응형

 

 

목차

     

     

    HTTP

    1. HTTP Method 속성

    1) 안전성(Safe)

    • GET 메소드(조회)는 안전함.
      • 저장된 데이터를 변환하지 않음.
    • POST, DELETE, PUT, PATCH는 안전하지 않음.
      • 각각 데이터를 생성, 수정, 삭제함.

     

    2) 멱등성(Idempotent)

    • 한 번을 호출하거나 수천번을 호출하거나 항상 결과는 같음.
      1. GET → 같은 결과가 계속 조회됨.
      2. PUT → 수정해서 대체된 후의 결과는 계속 같음.
      3. DELETE → 같은 요청을 여러 번 해도 삭제된 결과는 같음.
      4. POST → 멱등성을 보장하지 않음.
    • 요청이 실패한 경우 재시도 하기 위해 필요함.
      1. 항상 결과가 같다면 마음껏 재시도 해도 됨.
      2. 만약 멱등하지 않다면, 중복 요청을 보내서는 안됨.
      3. 복구 매커니즘에 사용함.
        • 요청 실패 시 서버에서 자동으로 재시도.
    • 리소스 조회(GET Method) 재요청 중간에 변경될 경우
      • 재요청 중간에 리소스가 변경되는 것은 멱등성으로 고려하지 않음.
        • ex) 도서관 책 재고 조회(실시간으로 대여되는 경우)

     

    3) 캐시가능성(Cacheable)

    • 재사용을 위해 요청에 대한 응답을 저장할 수 있는가?
      1. GET, HEAD, POST 메소드는 캐시 가능.
      2. 일반적으로 GET, HEAD 정도만 캐시로 사용함.
        • ex) 변경 가능성이 적은 정적자원(HTML, CSS, IMAGE, JS 등)을 주로 캐싱.
    💡캐시(Cache)란?
        - 클라이언트가 서버에 한 번 요청했던 데이터에 대해서 매번 요청할 때마다 다시 전송할 필요가 없도록 웹 브라우저가 임시적으로 데이터를 보관하고 있는 장소.

     

     

    2. HTTP 상태 코드

        - HTTP 요청에 대한 처리 상태를 응답하는 코드.

        - Data를 함께 응답함.

        - Spring에서는 Response를 커스텀하여 의미있는 메시지를 만들어서 사용하기도 함.

     

     

    • 1xx (정보)
      • 요청 수신 후 처리중인 상태.
      • 잘 사용하지 않음.
    • 2xx (성공)
      • 정상 처리 완료된 상태.
      • 대표 상태코드.
        • 200 OK
          • 요청 성공.
        • 201 Created
          • 새로운 리소스 생성.
        • 202 Accepted
          • 요청이 수신되었으나 처리가 완료되지 않음.
          • 주로 Batch 처리에서 사용됨.
            • ex) 설정한 시간마다 반복적으로 동작하는 특정 작업.
        • 204 No Content
          • 요청은 성공했지만, 응답 데이터가 없음.
            • ex) 저장, 작성 버튼 클릭 시.
    • 3xx(리다이렉션)
      • 요청을 완료하려면 추가 행동이 필요한 상태.
      • 3xx 응답 + Location HTTP Header가 있으면 Location 위치로 리다이렉트.
      • 리다이렉션 종류
        • 300은 사용하지 않는다.
        • 영구 리다이렉션
          • URL이 영구적으로 변경된 경우, 기존 URL을 사용하지 않음.
          • 301 Moved Permanently
            • 요청 메서드가 GET으로 변하고 본문이 제거될 수 있음.
          • 308 Permanent Redirect
            • 리다이렉트 시 요청 메서드와 본문 유지.
        • 일시 리다이렉션
          • URI가 일시적으로 변경된 경우
            • ex) 게시글 작성 후 게시글 목록 페이지로 이동, PRG 패턴.
          • PRG(Post, Redirect, Get) 패턴이란?
            • 게시글 작성(Post) → 응답(Redirect) → 리다이렉트 요청(Get)
          • PRG 패턴을 적용하지 않을 경우
            • 새로고침 시 요청이 중복으로 처리됨.
          • PRG 패턴을 적용할 경우
            • 새로고침을 하면 GET 요청을 함.
          • 대표 상태코드
            • 302 Found
              • 요청 메서드가 GET으로 변할 수 있음.
              • 모호해서 명확한 303, 307이 등장.
              • 이미 사용하고 있는곳이 많음. GET으로 변해도 상관없다면 사용해도 무방.
            • 303 See Other
              • 요청 메서드가 GET으로 변경됨.
            • 307 Temporary Redirect
              • 리다이렉트시 요청 메서드와 본문이 유지됨.
        • 기타 리다이렉션
          • 캐시를 활용할 것인지에 대한 여부
          • 대표 상태코드
            • 304 Not Modified
              • 캐시 목적으로 사용.
              • 리소스가 수정되지 않았다는 뜻, 클라이언트가 캐시된 데이터를 조회하도록 유도.
              • 응답에 바디가 있으면 안됨.
      • 4xx (클라이언트 에러)
        • 클라이언트측 오류, 잘못된 문법 등으로 서버가 요청을 수행할 수 없음.
        • 클라이언트의 요청이 잘못되었기 때문에 같은 요청의 재시도는 실패.
        • 대표 상태코드
          • 400 Bad Request
            • 클라이언트가 HTTP 요청 내용을 수정 후 보내야 함.
            ex) GET 메소드로 만들어진 API인데 POST로 보낸다?
            ex) API 스펙과 일치하지 않을 때, 숫자를 문자로, 문자를 숫자로.
          • 401 Unauthorized
            • 클라이언트가 리소스에 대한 인증(Authentication) 필요.
            • 응답에 WWW-Authenticate 헤더와 함께 인증 방법 설명.
            ex) 로그인
          • 403 Forbidden
            • 서버가 요청을 받았지만 승인 거부.
            • 주로 인가(Authorization) 관련문제.
            ex) 일반 유저, 관리자
          • 404 Not Found
            • 요청한 리소스가 서버에 없음.
            • 이를 이용하여 리소스를 숨겨놓기도 함
      • 5xx (서버 에러)
        • 서버 오류, 요청은 정상이지만 서버가 처리하지 못함
        • 재시도하면 성공할 수 있음.
          • ex) 서버가 일정시간 다운되었다가 다시 살아난 경우
        • 실제 서버에서 문제가 발생한 경우 5xx Error이기 때문에 발생하지 않는 것이 최선.
        • 대표 상태코드
          • 500 Internal Server Error
            • 대부분 500으로 처리.
          • 503 Service Unavailable
            • 서비스 이용 불가.
            • Retry-After Header를 사용하면 얼마뒤에 복구되는지 응답할 수 있음.

     

    아직까지는 200, 201, 400, 404, 500 정도를 많이 접하는 것 같다.

     

    3. 올바른 HTTP API 설계

    • 게시글 생성
      • POST
      • /boards
      • 성공시 상태코드 2xx
      • 실패시 4xx (클라이언트 문제) OR 5xx (서버 문제)
    • 게시글 1개 조회
      • GET
      • /boards/{id}
      • 성공시 상태코드 2xx
      • 실패시 4xx (클라이언트 문제) OR 5xx (서버 문제)
    • 게시글 목록 조회
      • GET
      • /boards
      • 성공시 상태코드 2xx
      • 실패시 4xx (클라이언트 문제) OR 5xx (서버 문제)
    • 게시글 수정
      • PUT or PATCH
      • /boards/{id}
      • 성공시 상태코드 2xx
      • 실패시 4xx (클라이언트 문제) OR 5xx (서버 문제)
    • 게시글 삭제
      • DELETE
      • /boards/{id}
      • 성공시 상태코드 2xx
      • 실패시 4xx (클라이언트 문제) OR 5xx (서버 문제)

     

    반응형