RESTful API
REST/REST API /RESTFul API 란?
스파이더웹
2022. 9. 18. 18:13
728x90
반응형
RESTFul API를 알기 전에 각각의 개념에 대해 알아보자
REST란?
“Representational State Transfer” 의 약자, 웹에 존재하는 모든 자원(이미지, 동영상 등)에 고유한 URI를 부여해 활용하는 것으로 자원을 정의하고 자원에 대한 주소를 지정하는 방법론을 의미한다.
즉, REST란
- HTTP URI(Uniform Resource Identifier)를 통해 자원(Resource)을 명시하고,
- HTTP Method(POST, GET, PUT, DELETE, PATCH 등)를 통해
- 해당 자원(URI)에 대한 CRUD Operation을 적용하는 것을 의미합니다.
CRUD Operation, HTTP Method
- Create : POST (자원 생성)
- Read : GET (자원 정보 조회)
- Update : PUT (자원의 정보 업데이트)
- Delete : DELETE (자원 삭제)
REST 구성 요소
- 자원 : HTTP URI
- 자원에 대한 행위 : HTTP Method
- 자원에 대한 행위의 내용 : HTTP Message Pay Load
REST 의 특징
- 클라이언트 / 서버 구조 (Client-Server)
자원이 있는 Server , 자원을 요청하는 Client의 구조를 가진다. - 무상태 (Stateless)
HTTP는 Stateless 프로토콜 이므로 REST 역시 무상태성을 가진다. 클라이언트의 Context 를 서버에 저장하지 않는다. - 캐시 처리 가능 (Cachealble)
웹 표준 HTTP 프로토콜을 그대로 사용하므로 , 웹에서 사용하는 기존의 인프라를 그대로 활용 가능하다. - 계층화
API 서버는 순수 비즈니스 로직을 수행하고 그 앞단에 사용자 인증 , 암호화 , 로드밸런싱 등을 하는 계층을 추가하여 구조상의 유연성을 줄 수 있다. - 인터페이스 일관성(Uniform Interface)
URI로 지정한 자원에 대한 조작을 통일되고 한정적인 인터페이스로 수행한다. HTTP 표준에만 따른다면 모든 플랫폼에 사용이 가능하다. - 자체 표현 구조
동사(Method) + 명사(URI) 로 이루어져있어 어떤 메서드에 무슨 행위를 하는지 알 수 있으며 REST API 자체가 매우 쉬워서 API 메세지 자체만 보고도 API를 이해할 수 있다
REST의 장단점
장점
- 쉬운 사용
HTTP 프로토콜 인프라를 그대로 사용하므로 별도의 인프라를 구축할 필요가 없다. - 클라이언트-서버 역할의 명확한 분리
클라이언트는 REST API를 통해 서버와 정보를 주고받는다. REST의 특징인 Stateless에 따라 서버는 클라이언트의 Context를 유지할 필요가 없다. - 특정 데이터 표현을 사용가능
REST API는 헤더 부분에 URI 처리 메소드를 명시하고 필요한 실제 데이터를 ‘body’에 표현할 수 있도록 분리시켰다. JSON , XML 등 원하는 Representation 언어로 사용 가능하다.
단점
- 메소드의 한계
REST는 HTTP 메소드를 이용하여 URI를 표현한다. 이러한 표현은 쉬운 사용이 가능하다는 장점이 있지만 반대로 메소드 형태가 제한적인 단점이 있다. - 표준이 없음
REST는 설계 가이드 일 뿐이지 표준이 아니다. 명확한 표준이 없다.
REST API
- REST의 원리를 따르는 API
REST API의 디자인 규칙
- URI 마지막에 슬래시를 포함하지 않는다
- 슬래시를 사용하여 계층적 관계를 나타낸다
- 언더바(_) 대신 하이폰(-)을 사용한다
- 파일 확장자는 URI에 포함하지 않는다
- URI는 소문자로 작성하고, 명사를 사용한다
- 행위를 포함하지 않고 복수형을 사용한다(http://n.com/create-board 처럼 행위를 포함하지 않는다)
RESTFul
RESTFUL이란 REST의 원리를 따르는 시스템을 의미합니다. 하지만 REST를 사용했다 하여 모두가 RESTful 한 것은 아닙니다. REST API의 설계 규칙을 올바르게 지킨 시스템을 RESTFul하다 말할 수 있으며
모든 CRUD 기능을 POST로 처리 하는 API 혹은 URI 규칙을 올바르게 지키지 않은 API는 REST API의 설계 규칙을 올바르게 지키지 못한 시스템은 REST API를 사용하였지만 RESTful 하지 못한 시스템이라고 할 수 있습니다.
728x90
반응형