[CS] HTTP

양갱장군·2020년 9월 22일
0

TIL

목록 보기
9/39

✅ HTTP

HTTP는 HyperText Transfer Protocol의 약자이다.

다시 말하면,
1) HyperText: HTML로 만든 웹페이지를
2) Transfer: 전송하는 (엄밀히 마하면 주고 받는)
3) Protocol: 약속(통신규약) 이란 뜻을 가진다.

✅ HTTP의 두가지 특징

⏩ Request/Response (요청/응답)

Transfer에는 보내는 주체와 받는 주체가 필요하다. 예를 들어 인스타그램에 접속해 친구의 인스타그램 스토리를 클릭한다면, 그 순간 컴퓨터는 서버에 "그 친구의 스토리를 보여달라"는 요청을 보내게 된다. 이 요청을 처리한 후 다시 내 컴퓨터에 응답을 보내면 마침내 친구의 스토리를 확인할 수 있게 되는 것이다.

⏩ Stateless

문자 그대로 번역하면 State(상태)+less(없음)을 의미한다. 이 말은 각각의 HTTP 통신(요청/응답)은 독립적 이기 때문에 과거의 통신(요청/응답)에 대한 내용을 전혀 알지 못한다는 말이다.
그렇기 때문에 매 통신마다 필요한 모든 정보를 담아서 요청을 보내야한다.

✅ Request, Response 구조

⏩ Request 메세지 구조

1. Start Line: 요청의 첫번째 줄에 해당하며, 이 부분도 3부분으로 구성되어 있다.
1) HTTP Method: 해당 요청이 의도한 액션을 정의하는 부분. 주로 GET, POST, DELETE가 많이 쓰임
2) Request target: 해당 request가 전송되는 목표 url
3) HTTP Version: 말 그대로 사용되는 HTTP 버전을 뜻한다. 주로 1.1 버전이 널리 쓰임

2. Headers: 해당 요청에 대한 추가 정보(메타 데이터)를 담고있는 부분이다.

3. Body: 해당 요청의 실제 내용

⏩ Response 메세지 구조

1. Status Line: 응답의 상태 줄이다. 응답은 요청에 대한 처리상태를 클라이언트에게 알려주면서 내용을 시작한다. 응답의 Status Line 도 3 부분으로 구성된다.
1) HTTP Version: 요청의 HTTP버전과 동일
2) Status Code: 응답 메세지의 상태 코드
3) Status Text: 응답 메세지의 상태를 간략하게 설명해주는 텍스트

2. Headers: 요청의 헤더와 동일하다. 응답의 추가 정보(메타 데이터)를 담고있는 부분이다. 다만, 응답에서만 사용되는 헤더의 정보들이 있다. (ex. 요청하는 브라우저의 정보가 담긴 User-Agent 대신, Server 헤더가 사용된다.)

3. Body: 요청의 Body와 일반적으로 동일하다. 가장 많이 사용되는 Body 의 데이터 타입은 JSON(JavaScript Object Notation) 이다.

예문(post method를 예시로)
(축약된 요청 메세지)
POST /shop/bag HTTP/1.1
Headers: {
	"HOST": "https://www.apple.com/kr"
	"Authroization": "kldiduajsadm@9df0asmzm" (유저가 본인임을 증명할 수 있는 인증/인가 토큰)
}
Body: {
	product: {
		"productId": 30
		"name": "12.9형 iPad Pro Wi-Fi + Cellular 128GB"
		"color": "스페이스 그레이"
		"price": "₩1,499,000"
		"quantity": 1
	}
}
(축약된 응답 메시지)
HTTP/1.1 201 SUCCESS
Body: {
	"message": "SUCCESSFULLY CARTS UPDATED"
}

✅ HTTP Request Methods

⏩ GET

  • 이름 그대로 어떤 데이터를 서버로 부터 받아(GET)올 때 주로 사용하는 메소드
  • 데이터를 받아오기만 할 때 사용된다.

⏩ POST

  • 데이터를 생성 / 수정 할 때 주로 사용되는 메소드
  • 데이터를 생성 및 수정 할 때 많이 사용되기 때문에 대부분의 경우 요청에 body가 포함되서 보내진다.

⏩ DELETE

  • 특정 데이터를 서버에서 삭제 요청을 보낼때 쓰는 메소드

✅ Response Status Codes

⏩ 200: OK

  • 문제없이 요청에 대한 처리가 백엔드 서버에서 이루어지고 나서 오는 응답코드

⏩ 201: Created

  • 무언가가 잘 생성되었을 때에(Successfully Created) 오는 Status Code

⏩ 400: Bad Request

  • 해당 요청이 잘못되었을 때 보내는 Status Code
  • 주로 요청의 Body에 보내는 내용이 잘못되었을 때 사용된다.

⏩ 401: Unauthorized

  • 유저가 해당 요청을 진행하려면 먼저 로그인을 하거나 회원가입이 필요하다는 의미

⏩ 403: Forbidden

  • 유저가 해당 요청에 대한 권한이 없다는 뜻
  • 접근 불가능한 정보에 접근했을 경우
    ex) 오직 유료회원만 접근할 수 있는 데이터를 요청 했을 때

⏩ 404: Not Found

  • 요청된 URI 가 존재하지 않는다는 의미

⏩ 500: Internal Server Error

  • 서버에서 에러가 났을 때의 Status Code

0개의 댓글