REST API란? (+API란?)

응갱·2022년 9월 6일
0

프로젝트를 진행하며 REST API에 대해 알아봐야 할 일이 생겼다. REST API란 REST를 기반으로 만들어진 API를 의미한다. 이렇게 말하면 어떤 말인지 직접적으로 와닿지 않는다. REST도 모르고 API도 모르기 때문이다.
REST API가 무엇인지 알아보기 전에 API가 무엇인지 알 필요가 있다!

📎API란?

API(Application Programming Interface)는 응용 프로그램에서 사용할 수 있도록, 운영 체제나 프로그래밍 언어가 제공하는 기능을 제어할 수 있게 만든 인터페이스를 뜻한다. -위키백과

API의 정의의 핵심은 두 소프트웨어가 서로 통신할 수 있게 연결한다는 점이다. 두 소프트웨어를 연결함으로써 사용자가 편리한 새로운 프로그램을 만드는데 이용할 수 있다.

API는 사용하는 방법과 용도에 따라 오픈 API비공개 API 정보가 있다. 오픈 API에 대해 많이 예시로 드는 정보가 기상청 API이다. 기상청 오픈 API는 기상청에서 수집하고 있는 정보를 사용자에게 쉽게 제공하기 위한 목적으로 만들어져 다양한 애플리케이션에 쓰이기 때문이다.

📎그렇다면 REST API는?!

REST API란 REST를 기반으로 만들어진 API를 의미한다.
이때, REST API는 HTTP 프로토콜을 그대로 사용하여 별도의 인프라 구축이 필요 없다.
REST(Representational State Transfer)는 자원을 이름으로 구분하여 해당 자원의 상태를 주고 받는 모든 것을 의미한다.

📎REST 구성 요소

  1. 자원(Resource): URI
  2. 자원에 대한 행위(Verb): HTTP Method
  3. 자원에 대한 행위의 표현(Representations)

REST 구성 요소를 통해 REST 에 대해 알아보면 다음과 같다.

  1. HTTP URI를 통해 자원(Resource)을 명시하고,
  2. HTTP Method를 통해
  3. 해당 자원(URI)에 대한 CRUD Operation을 적용하는 것을 의미한다.

이때, CRUD Operation이란 Create(데이터생성), Read(데이터 조회), Update(데이터 수정), Delete(데이터 삭제)의 기능을 묶어서 일컫는 말이다.

📎REST 특징

1) Uniform (유니폼 인터페이스)
Uniform Interface는 URI로 지정한 리소스에 대한 조작을 통일되고 한정적인 인터페이스로 수행하는 아키텍처 스타일을 말합니다.

2) Stateless (무상태성)
REST는 무상태성 성격을 갖습니다. 다시 말해 작업을 위한 상태정보를 따로 저장하고 관리하지 않습니다. 세션 정보나 쿠키정보를 별도로 저장하고 관리하지 않기 때문에 API 서버는 들어오는 요청만을 단순히 처리하면 됩니다. 때문에 서비스의 자유도가 높아지고 서버에서 불필요한 정보를 관리하지 않음으로써 구현이 단순해집니다.

3) Cacheable (캐시 가능)
REST의 가장 큰 특징 중 하나는 HTTP라는 기존 웹표준을 그대로 사용하기 때문에, 웹에서 사용하는 기존 인프라를 그대로 활용이 가능합니다. 따라서 HTTP가 가진 캐싱 기능이 적용 가능합니다. HTTP 프로토콜 표준에서 사용하는 Last-Modified태그나 E-Tag를 이용하면 캐싱 구현이 가능합니다.

4) Self-descriptiveness (자체 표현 구조)
REST의 또 다른 큰 특징 중 하나는 REST API 메시지만 보고도 이를 쉽게 이해 할 수 있는 자체 표현 구조로 되어 있다는 것입니다.

5) Client - Server 구조
REST 서버는 API 제공, 클라이언트는 사용자 인증이나 컨텍스트(세션, 로그인 정보)등을 직접 관리하는 구조로 각각의 역할이 확실히 구분되기 때문에 클라이언트와 서버에서 개발해야 할 내용이 명확해지고 서로간 의존성이 줄어들게 됩니다.

6) 계층형 구조
REST 서버는 다중 계층으로 구성될 수 있으며 보안, 로드 밸런싱, 암호화 계층을 추가해 구조상의 유연성을 둘 수 있고 PROXY, 게이트웨이 같은 네트워크 기반의 중간매체를 사용할 수 있게 합니다.

📎REST API 중심 규칙

  1. URI는 정보의 자원을 표현해야 한다.
  2. 자원에 대한 행위는 HTTP Method(GET, POST 등)로 표현

📎REST API 설계 예시

  1. URI는 동사보다는 명사를, 대문자보다는 소문자를 사용하여야 한다.
  2. 마지막에 슬래시(/)를 포함하지 않는다.
  3. 언더바 대신 하이폰을 사용한다.
  4. 파일확장자는 URI에 포함하지 않는다.
  5. 행위를 포함하지 않는다.

출처

https://meetup.toast.com/posts/92
https://khj93.tistory.com/entry/%EB%84%A4%ED%8A%B8%EC%9B%8C%ED%81%AC-REST-API%EB%9E%80-REST-RESTful%EC%9D%B4%EB%9E%80
https://brunch.co.kr/@operator/65
https://steemit.com/kr/@yahweh87/it-api

profile
🥔 한 덩이

0개의 댓글