∞. 기술 면접/2. 네트워크

05. 기술면접 - 네트워크 - GET 과 POST

THE HEYDAZE 2021. 9. 30. 14:01

GET 메서드와 POST 메서드

  • HTTP 프로토콜을 이용해서 서버에 데이터(요청 정보)를 전달할 때 사용하는 방식
  • GET 메서드 방식
    • https://mangkyu.tistory.com/17
       
    • 개념
      • 정보를 조회하기 위한 메서드
      • 서버에서 어떤 데이터를 가져와서 보여주기 위한 용도의 메서드
      • 가져오는 것(Select)
    • 사용 방법
      • URL의 끝에 '?'가 붙고, 요청 정보가 (key=value)형태의 쌍을 이루어 ?뒤에 이어서 붙어 서버로 전송한다.
      • 요청 정보가 여러 개일 경우에는 '&'로 구분한다.
      • Ex) www.urladdress.xyz?name1=value1&name2=value2
    • 특징
      • URL에 요청 정보를 붙여서 전송한다.
      • URL에 요청 정보가 이어붙기 때문에 길이 제한이 있어서 대용량의 데이터를 전송하기 어렵다.
        • 한 번 요청 시 전송 데이터(주솟값 + 파라미터)의 양은 255자로 제한된다.(HTTP/1.1은 2048자)
          HTTP 자체는 GET 방식의 URL 길이에 제약을 두고 있지는 않지만, 브라우저에서 최대 길이를 제한함
          만약 브라우저에서 길이를 초과하여 서버에 요청하는 경우 초과데이터는 절단됩니다

      • 요청 정보를 사용자가 쉽게 눈으로 확인할 수 있다.
        • POST 방식보다 보안상 취약하다.
      • HTTP 패킷의 Body는 비어 있는 상태로 전송한다.
        • 즉, Body의 데이터 타입을 표현하는 'Content-Type' 필드도 HTTP Request Header에 들어가지 않는다.
      • POST 방식보다 빠르다.
        • GET 방식은 캐싱을 사용할 수 있어, GET 요청과 그에 대한 응답이 브라우저에 의해 캐쉬된다.
      • 크롬 브라우저만 그런지 몰라도 주소창에 주소를 치는 도중에 엔터를 치지않아도 해당서버로 GET 요청이 나간다 
  • POST 메서드 방식
    • 개념
      • 서버의 값이나 상태를 바꾸기 위한 용도의 메서드
      • 수행하는 것(Insert, Update, Delete)
      • https://mangkyu.tistory.com/17
    • 사용 방법
      • 요청 정보를 HTTP 패킷의 Body 안에 숨겨서 서버로 전송한다.
      • Request Header의 Content-Type에 해당 데이터 타입이 표현되며, 전송하고자 하는 데이터 타입을 적어주어야 한다.
        • Default: application/octet-stream
        • 단순 txt의 경우: text/plain
        • 파일의 경우: multipart/form-date
    • 특징
      • Body 안에 숨겨서 요청 정보를 전송하기 때문에 대용량의 데이터를 전송하기에 적합하다.
      • 클라이언트 쪽에서 데이터를 인코딩하여 서버로 전송하고, 이를 받은 서버 쪽이 해당 데이터를 디코딩한다.
      • GET 방식보다 보안상 안전하다.
  • Q. 조회하기 위한 용도 POST가 아닌 GET 방식을 사용하는 이유?
    1. 설계 원칙에 따라 GET 방식은 서버에게 여러 번 요청을 하더라도 동일한 응답이 돌아와야 한다. (Idempotent, 멱등)
      • GET 방식은 가져오는 것(Select) 으로, 서버의 데이터나 상태를 변경시키지 않아야 한다.
        • Ex) 게시판의 리스트, 게시글 보기 기능
        • 예외) 방문자의 로그 남기기, 글을 읽은 횟수 증가 기능
      • POST 방식은 수행하는 것 으로, 서버의 값이나 상태를 바꾸기 위한 용도이다.
        • Ex) 게시판에 글쓰기 기능
    2. 웹에서 모든 리소스는 Link할 수 있는 URL을 가지고 있어야 한다.
      • 어떤 웹페이지를 보고 있을 때 다른 사람한테 그 주소를 주기 위해서 주소창의 URL을 복사해서 줄 수 있어야 한다.
      • 즉, 어떤 웹페이지를 조회할 때 원하는 페이지로 바로 이동하거나 이동시키기 위해서는 해당 링크의 정보가 필요하다.
      • 이때 POST 방식을 사용할 경우에 값(링크의 정보)이 Body에 있기 때문에 URL만 전달할 수 없으므로 GET 방식을 사용해야한다. 그러나 글을 저장하는 경우에는 URL을 제공할 필요가 없기 때문에 POST 방식을 사용한다.

https://mangkyu.tistory.com/17