HTTP란?

Minho Yoo·2022년 7월 19일
4
post-thumbnail

HTTP (Hyper Text Transfer Protocol)

HTTP 는 브라우저가 웹 서버와 통신하기 위해 사용하는 주요 프로토콜이다.

HTTP 프로토콜이란?

HTTP(Hyper Text Transfer Protocol)는 웹을 개발하는 사람이라면 누구나 다 알아야 하는 통신 프로토콜이다.
웹에서는 브라우저와 서버 간에 데이터를 주고받기 위한 방식으로 HTTP 프로토콜을 사용하고 있으며 프론트엔드 개발자라면 필수적으로 알아야 하는 지식이다.

프로토콜

상호 간에 정의한 규칙을 의미하며 특정 기기 간에 데이터를 주고받기 위해 정의되었다.

HTTP 프로토콜 특징

HTTP 프로토콜은 상태가 없는(stateless) 프로토콜이다.
여기서 상태가 없다라는 말은 데이터를 주고 받기 위한 각각의 데이터 요청이 서로 독립적으로 관리가 된다는 말이다.
좀 더 쉽게 말해 이전 데이터 요청과 다음 데이터 요청이 서로 관련이 없다라는 것이다.
이러한 특징 덕에 서버는 세션과 같은 별도의 추가 정보를 관리하지 않아도 되고, 다수의 요청 처리 및 서버의 부하를 줄일 수 있는 성능 상의 이점이 생긴다.

HTTP 프로토콜은 일반적으로 TCP/IP 통신 위에서 동작하며 기본 포트는 80번이다.

HTTP Request & HTTP Response

HTTP 프로토콜로 데이터를 주고받기 위해서는 아래와 같이 요청(Request)을 보내고 응답(Response)을 받아야 한다.

그리고 요청과 응답을 이해하기 위해서는 먼저 클라이언트(Client)와 서버(Server)를 이해해야 한다.

클라이언트

요청을 보내는 쪽을 의미하며 일반적으로 웹 관점에서는 브라우저를 의미한다.

서버

요청을 받는 쪽을 의미하며 일반적으로 데이터를 보내주는 원격자의 컴퓨터를 의미한다.

URL

URL(Uniform Resource Locators)은 개발자가 아니더라도 이미 우리에게 익숙한 용어이다.
서버에 자원을 요청하기 위해 입력하는 영문 주소이고, 숫자로 되어 있는 IP 주소보다는 훨씬 기억하기 쉽기 때문에 사용한다.

URL 구조

HTTP 요청 메서드

앞으로 살펴본 URL을 이용하면 서버에 특정 데이터를 요청할 수 있다.
여기서 요청하는 데이터에 특정 동작을 수행하기 위해서는 HTTP 요청 메서드(Http Request Methods)를 이용한다.
일반적으로 HTTP 요청 메서드는 HTTP Verbs라고도 하며, 아래와 같이 주요 메서드를 가지고 있다.

GET: 존재하는 자원에 대한 요청
POST: 새로운 자원을 생성
PUT: 존재하는 자원에 대한 변경
DELETE: 존재하는 자원에 대한 삭제

이와 같이 데이터에 대한 조회, 생성, 변경, 삭제 동작을 HTTP 요청 메서드로 정의할 수 있다.
참고로 때에 따라서는 POST 메서드로 PUT, DELETE 동작도 수행할 수 있다.

기타 메서드

HEAD: 서버 헤더 정보를 획득. GET과 빗스하나 Response Body를 반환하지 않음
OPTIONS: 서버 옵션들을 확인하기 위한 요청. CORS에서 사용

HTTP 상태 코드

앞에서 살펴본 URL과 요청 메서드가 클라이언트에서 설정해야 할 정보라면 HTTP 상태 코드(HTTP Status Code)는 서버에서 설정해주는 응답(Response) 정보이다.
프론트엔드 개발자 입장에서는 더욱이 중요한 이유가 이 상태 코드로 에러 처리를 할 수 있기 때문이다.

http://domain.com/user

위 요청을 보내고 나면 서버에서 응답으로 오는 상태 코드가 크게 2개로 나뉜다.
200(성공)과, 404(실패)로 나뉘게 되고 HTTP 상태 코드로 추가적인 로직을 구현할 수 있다.

주요 상태 코드는 200번대에서 500번대까지 다양하게 있지만 주요한 상태 코드만 몇개 살펴보자.

2xx - 성공

200 번대의 상태 코드는 대부분 성공을 의미한다.

200: GET 요청에 대한 성공
204: No Content. 성공했으나 응답 본문에 데이터가 없음
205: Reset Content. 성공했으나 클라이언트의 화면을 새로 고침하도록 권고
206: Partial Conent. 성공했으나 일부 범위의 데이터만 반환

3xx - 리다이렉션

300번대의 상태 코드는 대부분 클라이언트가 이전 주소로 데이터를 요청하여 서버에서 새 URL로 리다이렉트를 유도하는 경우이다.

301: Moved Permanently. 요청한 자원이 새 URL에 존재
303: See Other. 요청한 자원이 임시 주소에 존재
304: Not Modified, 요청한 자원이 변경되지 않았으므로 클라이언트에서 캣이된 자원을 사용하도록 권고. ETag와 같은 정보를 활용하여 변경 여부를 확인

4xx - 클라이언트 에러

400번대 상태 코드는 대부분 클라이언트의 코드가 잘못된 경우이다.
유효하지 않은 지원을 요청했거나 요청이나 권한이 잘못된 경우 발생한다.
가장 익숙한 상태 코드는 404 코드이고, 요청한 자원이 서버에 없다는 의미이다.

400: Bad Request, 잘못된 요청
401: Unauthorized, 권한 없이 요청. Authorization 헤더가 잘못된 경우
403: Forbidden, 서버에서 해당 자원에 대해 접근 금지
405: Method Not Allowed, 허용되지 않은 요청 메서드
409: Conflict, 최신 자원이 아닌데 업데이트하는 경우. 예) 파일 업로드 시 버전 충돌

5xx - 서버 에러

500번대 상태 코드는 서버 쪽에서 오류가 난 경우입니다.

501: Not Implemented, 요청한 동작에 대해 서버가 수행할 수 없는 경우
503: Service Unavailable, 서버가 과부하 또는 유지 보수로 내려간 경우

profile
Always happy coding 😊

0개의 댓글