GET과 POST 요청 방식의 차이는 무엇인가?
URL에 데이터가 있는 것은 GET방식, URL에 데이터가 없고 메시지 본문에 있는 것은 POST방식
GET요청의 특징
- URL에 데이터를 포함 - 데이터 조회에 적합
- 바이너리 및 대용량 데이터 전송 불가
- 요청라인과 헤드 필드의 최대 크기
* HTTP 사양에는 제한사항 없음
* 대용량 URL로 인한 문제 발생 => 웹 서버에 따라 최대 크기 제한
* 마이크로소프트 IIS 6.0 16KB
* APACHE 웹 서버 8KB
GET요청의 데이터 전달 형식은 어떻게 되는가?
서비스 주소 ? V1 = 23 & V2 = 15
서비스주소와 데이터를 ? 라는 문자를 이용해서 구분한다.
예) http://www.naver.com?v1=23&v2=15
GET 요청의 장점은 무엇인가?
URL에 데이터가 섞여 있기 때문에 결과 화면을 다른 사람들과 공유 할 수 있다.
링크를 클릭하게 되면 바로 결과화면을 볼 수 있다.
GET 요청의 문제점은 무엇인가?
(1) 보안에 좋지 않다.
주소에 데이터가 섞여있기 때문에 사용자의 로그인이나 중요 정보 요청에서 데이터가 밖으로 보인다.
그렇기 때문에 보안상의 이슈가 발생 할 수 있다.
(2) 바이너리 데이터를 전송 할 수 없다.
파일의 데이터는 URL에 붙여서 전송 할 수 없다.
BASE 64라는 인코딩 방식을 통해 바이너리 데이터를 문자화해서 보낼 수도 있지만, URI나 헤더 정보가 너무 크면
웹 서버에서 처리 할 수 없다.
이런 것은 POST를 통해 전송해야 한다.
POST요청의 특징
- URL에 데이터가 포함되지 않음 => 외부 노출 방지
- 메시지본문에 데이터 포함 => 실행 결과 공유 불가
- 바이너리 및 대용량 데이터 전송 가능
POST요청의 요청은 어떻게 이루어지는가?
요청라인과 요청헤더 다음에 공백라인이 있고 그 다음에 메시지 본문(Message Body)라 불리는 부분에 데이터가 위치해서 전송된다.
POST요청의 장점은 무엇인가?
입력값을 URL에 노출 시키지 않는다. 당연히 보안상으로 GET에 비해 좋다.
폼 태그를 통해 보내진 POST데이터는 Content-Length 와 Content-Type 등으로 구분한다.
Content-Type은 기본적으로 application/x-www-form-urlencoded형식으로 인코딩되어 보내진다.
POST요청의 문제점은 무엇인가?
(1) 요청 결과를 공유 할 수 없다.
즐겨찾기, 메일 등으로 그 결과값을 공유 할 수 없다.
POST요청은 데이터를 메시지 본문에 붙여서 전송하기 때문이다.
(2) GET방식과 마찬가지로 POST도 데이터를 전달 할 때 '이름=값&이름=값'형태로 보내진다.
결국 문자데이터를 보낼 때는 상관없지만 바이너리 데이터 등을 전송할 때는 이러한 '='이나 '&'값이 섞여 있을 수 있기 때문에 문제가 발생할 수 있다.
그래서 바이너리 데이터 등을 보낼 때는 멀티 파트 인코딩 방식을 통해 보내야 한다.
멀티 파트 인코딩 방식은 어떨때 사용하며 그렇게 사용하는 이유는 무엇인가?
POST형식 역시 데시지 본문에 '이름=값&이름=값'형태로 보내지기 때문에
바이너리 데이터에 혹시 = 이나 &가 섞여있으면 문제가 발생 할 수 있다.
그래서 멀티 파트 인코딩 방식을 사용하여 요청정보와 데이터를 확실히 구분 할 수 있게 한다.
예를들어 <form>태그의 enctype 속성을 'multipart/form-data'로 지정해서 file 전송을 할 수 있게 합니다.
'네트워크' 카테고리의 다른 글
동기 vs 비동기 (0) | 2015.10.06 |
---|---|
빅 엔디안(Big Endian) vs 리틀 엔티안(Little Endian) (0) | 2015.09.14 |
HTTP 와 HTTPS (0) | 2015.08.08 |
HTTP 프로토콜 (0) | 2015.08.08 |
쿠키와 세션의 차이 (0) | 2015.08.08 |