상세 컨텐츠

본문 제목

[패스트캠퍼스] 웹 개발 개론 - REST API

카테고리 없음

by 매일매일 배우는 개발자 2021. 7. 25. 13:36

본문

728x90

REST란?

Representational State Transfer : 자원의 상태 전달 - 네트워크 아키텍처

  1. Clint, Server : 클라이언트와 서버가 서로 덕립적으로 분리되어 있어야 한다.
  2. Stateless : 요청에 대해서 클라이언트의 상태를 서버에 저장하지 않는다. 
    1. 예) 햄버거 가게 : 햄버거 주문하는데 햄버거의 주문상태는 바뀌지 않는다.
  3. Cache : 클라이언트는 서버의 응답을 Cache(임시저장) 할 수 있어야 한다. 클라이언트가 Cache를 통해서 응답을 재사용할수 있어야 하며, 이를 통해서 서버의 부하를 낮춘다.
  4. 계층화 (Layered System) : 서버와 클라이언트 사이에 방화벽, 게이트웨이, Proxy등 다양한 계층 형태로 구성이 가능해야 하며, 이를 확장 할 수 있어야 한다.
  5. 인터페이스 일관성 : 인터페이스의 일관성을 지키고, 아키텍처를 단순화시켜 작은 단위로 분리하여, 클라이언트, 서버가 독립적으로 개선 될 수 있어야 한다.
  6. Code on Demand (Optional) : 자바 애플릿, 자바스크립트, 플래시 등 특정한 기능을 서버로부터 클라이언트가 전달받아 코드를 실행 할 수 있어야 한다.

 

다음의 인터페이스를 일광성이 잘 지켜졌는지에 따라, REST를 잘 사용했는지 판단을 할 수 있다.

  1. 자원의 식별
  2. 메시지를 통한 리소스 조작
  3. 자기 서술적 메시지
  4. 애플리케이션 상태에 대한 엔진으로써 하이퍼미디어

 

1. 자원의 식별 - 웹 기반의 REST에서는 리소스 접근을 할 때 URI를 사용 합니다

ex) http://foo.co.kr/user/100 

Resource : user

식별자 : 100

 

2.메시지를 통한 리소스 조작 - Web에서는 다양한 방식으로 데이터를 전달 할 수 있다.

예) HTML, XML, JSON, TEXT등

이 중에서 어떠한 타입의 데이터인지를 알려주기 위해 HTTP Header부분에 content-type을 통해 데이터 타입을 지정해줄 수 있다.

또한, 리소스 조작을 위해서 데이터 전체를 전달하지 않고, 이를 메시지를 전달 합니다.

 

3. 자기 서술적 메시지 - 요청하는 데이터가 어떻게 처리 되어져야 하는지 충분한 데이터를 포함 할 수 있어야 한다.

HTTP 기반의 REST에서는 HTTP Method와 Header정보, 그리고 URI의 포함되는 정보로 표현 할 수 있습니다.

 

GET : http://foo.co.kr/user/100 // 사용자의 정보 요청

POST : http://foo.co.kr/user // 사용자의 정보 생성

PUT : http://foo.co.kr/user // 사용자의 정보 생성 및 수정

DELETE : http://foo.co.kr/user/100  사용자의 정보 삭제 

 

4. 애플리케이션 상태에 대한 엔진으로써 하이퍼미디어

 

REST API를 개발할 때 단순히 Client 요청에 대한 데이터만 응답 해주는 것이 아닌 관련된 리소스에 대한 Link 정보까지 같이 포함 되어져야 한다.

 

이러한 조건들을 잘 갖춘 경우 REST ful 하다고 표현하고, 이를 REST API라고 부릅니다.

 

728x90