로춘남 2021. 3. 18. 14:47
728x90

http 프로토콜이 제공해주는 7가지 메소드 중 웹 서비스 개발에 주요 사용하는 GET과 POST


GET메서드 POST메서드 란?

 

웹 서비스 개발에 주로 사용하는 메소드.

사용자가 URL을 브라우저 주소창에 작성하고 엔터를 누르면 원하는 웹페이지가 나옴.

사용자는 웹페이지를 보기위해 단순한 일을 한 것 이지만, 특정 웹페이지를 사용자 웹브라우저에게 보여주기 위해서는 내부적인 처리들이 있음.

그 내부적인 처리에서, 클라이언트가 서버에게 웹페이지를 보여달라고 말하는 것을 우리는 요청(Request) 이라 부르고, 서버가 클라이언트에게 요청받은 것에 대한 대답으로, 웹페이지 내용을 표현하기 위해 html문서로 주는것 응답(Response) 이라 부른다.


HTTP 패킷

 

클라이언트가 서버로 요청을 했을때, 보내는 데이터를 HTTP 패킷이라 표현. 

HTTP 프로토콜을 쓰므로, 앞에 HTTP가 붙고 인터넷을 통해 보내는 데이터를 패킷이라 표현하므로,

HTTP패킷 이라 부른다. HTTP패킷의 구조는 크게 헤더(Header)  바디(Body)로 나뉘어진다.

헤더에는 7가지 HTTP 메서드 방식중 무엇을 썻는지, 클라이언트의 정보, 브라우저 정보,

접속할 URL 등등 과 같은 클라이언트 정보를 담는다. 

바디는 보통 비어있다. 하지만, 특정 데이터를 담아서 서버에게 요청을 보낼 수 있다.

이러한 웹 개념아래, 우리는 GET메서드와 POST메서드를 통해서 요청을 할 수 있다.


GET방식 vs POST방식

 

두 방식 모두, 서버에 요청을 하는 메소드. 클라이언트가 서버에 요청을 할때, 제공해야 하는 자원이 있다고 하자. 

예를 들면, 어떤 홈페이지의 로그인 페이지에서 로그인을 하는 경우이다.

아이디 와 패스워드는 클라이언트가 작성한 후, 그 정보를 서버에 요청하여 클라이언트가 작성한 아이디와 패스워드가 올바른 것인지 검사를 해야한다.

위의 예시를 보듯, 요청에는 자원을 보내야 하는경우가 존재한다.

 

  • GET방식으로 데이터를 보내기

클라이언트의 데이터를 URL뒤에 붙여서 보낸다. 위에서 쓴 예시처럼 아이디 패스워드를 보낸다고 하면,

www.example.com?id=test&pass=1234 (예시로 쓴 URL)

이런식으로 보낸다. URL 뒤에 "?" 마크를 통해 URL의 끝을 알리면서, 데이터 표현의 시작점을 알린다.

데이터는 key 와 value 쌍으로 넣어야 한다 윗 예시에서의 key는 id 랑 pass고 value는 test랑 1234가 되겠다.
중간에 &마크는 구분자 이다. 2개이상의 key - value 쌍 데이터를 보낼때는 &마크로 구분해준다.

URL에 붙이므로, HTTP패킷의 해더에 포함되여 서버에 요청한다.

따라서, GET 방식에서 BODY에 특별한 내용을 넣을 것이 없으므로 BODY가 빈상태로 보내진다.

그러므로, 헤더의 내용중 BODY 데이터를 설명하는 Content-Type이라는 헤더필드는 들어가지 않는다.

URL형태로 표현되므로, 특정 페이지를 다른사람 에게 접속하게 할 수 있다. 

또한 간단한 데이터를 넣도록 설계되어, 데이터를 보내는 양의 한계가 있다.

 

  • POST방식으로 데이터를 보내기

POST 방식은 GET 방식과 달리, 데이터 전송을 기반으로 한 요청 메서드이다.

GET방식은 URL에 데이터를 붙여서 보내는 반면, POST방식은 URL에 붙여서 보내지 않고

BODY에다가 데이터를 넣어서 보낸다.  

따라서, 헤더필드중 BODY의 데이터를 설명하는 Content-Type이라는 헤더 필드가

들어가고 어떤 데이터 타입인지 명시한다.

컨텐츠 타입으로는 여러가지가 있지만, 몇가지를 적자면,

 

  1. application/x-www-form-urlencoded
  2. text/plain
  3. multipart/form-data

등이 있다.

 

따라서 POST 방식으로 데이터를 보낼때는 위와 같이 컨텐츠 타입을 꼭 명시해줘야한다.

보통 작성하지 않는 경우는 1번의 컨텐츠 타입으로 셋팅된다.

1번의 컨텐츠 타입은, GET방식과 마찬가지로 BODY에 key 와 value 쌍으로 데이터를 넣는다. 똑같이 구분자 &를 쓴다.

2번의 컨텐츠 타입은, BODY에 단순 txt를 넣는다.

3번의 컨텐츠 타입은, 파일전송을 할때 많이 쓰는데 BODY의 데이터를 바이너리 데이터로 넣는다는걸 알려준다.

자바와 같이 oop 프로그래밍에서는 BODY에 데이터를 InputStream/OutputStream 클래스를 통해서 읽고/쓰고 한다.

 


GET방식 과 POST방식에 대한 상식

 

  • POST방식이 GET방식보다 보안측면에서 더 좋다?

POST든 GET이든 보내는 데이터는 전부 클라이언트측에서 볼 수 있다. 단지 GET방식은 URL에 데이터가 표시되여 별다른 노력없이 볼 수 있어서지, 두 방식 전부 보안을 생각한다면 암호화 해야한다.

 

  • GET방식이 POST방식보다 속도가 빠르다?

빠른건 맞다. 하지만 왜 빠른지를 알아야 하는데, 이유는 GET방식의 요청은 캐싱(한번 접근 후, 또 요청할 시 빠르게 접근하기 위해 데이터를 저장시켜 놓는다)때문에 빠른것이다.



출처: https://mommoo.tistory.com/60 [개발자로 홀로 서기]

728x90