GET과 POST는 둘 다 HTTP 프로토콜을 이용해서 서버에 무엇인가를 요청할 때 사용하는 방식이다.
GET 방식은 요청하는 데이터가 HTTP Request Message의 Header 부분에 url에 담겨서 전송된다. 때문에 url 상에 ? 뒤에 데이터가 파라미터 형식으로 붙어 request를 보내게 되는 것이다.
이러한 방식은 url이라는 공간에 담겨 전송되기 때문에 전송할 수 있는 데이터의 크기가 제한적이다. 또한, 보안이 필요한 데이터(비밀번호 등)에 대해서는 데이터가 그대로 노출되므로 GET 방식은 적절하지 않다.
POST 방식의 request는 HTTP Request Message의 Body 부분에 데이터가 담겨서 전송된다. 때문에 바이너리 데이터를 요청하는 경우 POST 방식으로 보내야 하는 것처럼 데이터 크기가 GET 방식보다 크고 보안면에서 낫다. (하지만 보안적인 측면에서는 암호화를 하지 않는 이상 비슷하다.)
이러한 특성을 이해한 뒤 어디에 적용되는지 알아봐야 그 차이를 극명하게 이해할 수 있다.
우선 GET은 가져오는 것이다. 서버에서 어떤 데이터를 가져와서 보여주는 용도이지 서버의 값이난 상태 등을 변경하지 않는다. SELECT적인 성향을 갖는다고 볼 수 있다.
반면, POST는 서버의 값이나 상태를 변경하기 위해서 또는 추가하기 위해 사용된다.
부수적인 차이점을 조금 더 살펴본다면 GET 방식의 요청은 브라우저에서 Caching 할 수 있다. 때문에 POST 방식으로 요청해야 할 것을 보내는 데이터의 크기가 작고 보안적인 문제가 없다는 이유로 GET 방식으로 요청한다면 기존에 Caching 되었던 데이터가 응답될 가능성이 존재한다. 따라서 목적에 맞는 기술을 사용해야 한다.