목록HTTP (7)
mojo's Blog
※ 캐시 기본 동작 캐시가 없을 때 첫 번째 요청이 아래와 같이 수행된다고 가정해본다. 첫 번째 요청이 완료되면 두 번째 요청이 수행된다고 가정해본다. 위와 같이 데이터가 변경되지 않아도 계속 네트워크를 통해서 데이터를 다운로드 받아야 한다. 인터넷 네트워크는 매우 느리고 비싸며 브라우저 로딩 속도가 느리다. 이번엔 캐시를 적용하여 첫 번째 요청이 수행된다고 가정해본다. 첫 번째 요청이 완료되면 두 번째 요청이 수행된다고 가정해본다. 캐시를 적용함으로써 캐시 가능 시간동안 네트워크를 사용하지 않아도 된다. 비싼 네트워크 사용량을 줄일 수 있고 브라우저 로딩 속도가 매우 빠르다. 이번엔 캐시 시간이 초과된 상태에서 세 번째 요청이 수행된다고 가정해본다. 캐시 유효 시간이 초과하면, 서버를 통해 데이터를 다..
HTTP 헤더 개요 ※ HTTP BODY (message body - RFC7230) HTTP/1.1 200 OK Content-Type: text/html;charset=UTF-8 Content-Length: 3423 ... 메시지 본문(message body)을 통해 표현 데이터를 전달한다. ( ~ ) 메시지 본문은 페이로드(payload)이다. 표현은 요청이나 응답에서 전달할 실제 데이터이다. 표현 헤더는 표현 데이터를 해석할 수 있는 정보를 제공한다. (데이터 유형(html, json), 데이터 길이, 압축 정보 등) Representation = Representation Metadata + Representation Data ※ 표현 Content-Type : 표현 데이터의 형식이다. (ex ..
HTTP 상태코드 소개 상태 코드란? 클라이언트가 보낸 요청의 처리 상태를 응답에서 알려주는 기능이다. 1xx (informational) : 요청이 수신되어 처리중이다. 2xx (Successful) : 요청이 정상 처리되었다. 3xx (Redirection) : 요청을 완료하려면 추가 행동이 필요하다. 4xx (Client Error) : 클라이언트 오류로 잘못된 문법등으로 서버가 요청을 수행할 수 없다. 5xx (Server Error) : 서버 오류로 서버가 정상 요청을 처리하지 못한다. 만약 모르는 상태코드가 나타난다면? 클라이언트가 인식할 수 없는 상태코드를 서버가 반환한다면 클라이언트는 상위 상태코드로 해석해서 처리한다. 미래에 새로운 상태 코드가 추가되어도 클라이언트를 변경하지 않아도 된다..
HTTP API ※ API URI 고민 (URI - Uniform Resource Identifier) 리소스의 의미는 회원을 등록하고 수정하고 조회하는게 리소스가 아니고 회원이라는 개념 자체가 바로 리소스이다. 리소스를 어떻게 식별하냐면 회원을 등록하고 수정하고 조회하는 것을 모두 배제하며 회원이이라는 리소스만 식별하면 된다. (회원 리소스를 URI에 매핑) 회원 목록 조회 : /members 회원 조회 : /members/{id} -> 구분하기 어려움 회원 등록 : /members/{id} -> 구분하기 어려움 회원 수정 : /members/{id} -> 구분하기 어려움 회원 삭제 : /members/{id} -> 구분하기 어려움 계층 구조상 상위를 컬렉션으로 보고 복수단어 사용을 권장한다. (mem..
모든 것이 HTTP ※ HTTP (HyperText Transfer Protocol) HTML, TEXT 를 전송한다. Image, 음성, 영상, 파일을 전송한다. JSON, XML (API) 를 전송한다. 거의 모든 형태의 데이터 전송이 가능하다. 서버간에 데이터를 주고 받을 때도 대부분 HTTP를 사용한다. ※ 기반 프로토콜 TCP는 HTTP/1.1, HTTP/2 를 사용한다. UDP는 HTTP/3 를 사용한다. 현재 HTTP/1.1 을 주로 사용하며 HTTP/2, HTTP/3 도 점점 증가하는 추세이다. 실제로 어떤 프로토콜을 사용하는지 확인할 수 있다. 일단 크롬에 이동해서 F12 를 누르고 검색창에 아무거나 입력한다. 그리고 Name 쪽에 오른쪽 마우스를 클릭한 후 Protocol을 누른다. 그..
URI ※ URI(Uniform Resource Identifier) 로케이터, 이름 또는 둘 다 추가로 분류될 수 있다. 예를 들어서 알아보도록 한다. URL ex ) foo://example.com:8042/over/there?name=ferret#nose (평소에 보던 URL) URN ex ) animal, ferret, nose, ... (이름 그 자체) ※ URI Uniform : 리소스를 식별하는 통일된 방식 Resource : 자원, URI로 식별할 수 있는 모든 것(제한 x) Identifier : 다른 항목과 구분하는데 필요한 정보 ※ URL, URN URL - Locator : 리소스가 있는 위치를 지정 URN - Name : 리소스에 이름을 부여 위치는 변할 수 있지만, 이름은 변하지..