BACKEND/SPRING

02. 개발에 앞서 알면 좋은 기초 지식 - REST API

우진하다 2023. 7. 22. 18:11

REST API

REST API는 대중적으로 가장 ㅁ낳이 사용되는 애플리케이션 인터페이스입니다.
이 인터페이스를 통해 클라이언트는 서버에 접근하고 자원을 조작할 수 있습니다.

REST란?

REST란 Representational State Transfer의 약자로, 월드 와이 웹과 같은 분산 하이퍼미디어 시스템 아키텍처의 한 형식입니다.
주고 받는 자원에 이름을 규정하고 URI에 명시해 HTTP 메서드를 통해 해당 자원의 상태를 주고 받는 것을 의미합니다.

REST API란?

API는 Application Prgramming Interface의 약자로, 애플리케이션에서 제공하는 인터페이스를 의미합니다.
API를 통해 서버 또는 프로그램 사이를 연결할 수 있습니다.
REST API란 REST 아키텍처를 따르는 시스템/애플리케이션 인터페이스라고 볼 수 있습니다.
REST 아키텍처를 구현하는 웹 서비스를 'RESTful'하다 라고 표현합니다.

REST의 특징

유니폼 인터페이스
유니폼 인터페이스란 '일관된 인터페이스'를 의미합니다. 
즉, REST 서버는 HTTP 표준 전송 규약을 따 르기 때문에 어떤 프로그래밍 언어로 만들어졌느냐와 상관없이 플랫폼 및 기술에 종속되지 않고 타 언이, 플랫폼, 기술 등과 호환해 사용할 수 있다는 것을 의미합니다.

무상태성 
REST는 '무상태성(stateless)'이라는 특징을 가집니다. 
무상태성이란 서비에 상태 정보를 따로 보관하 거나 관리하지 않는다는 의미입니다. 
서버는 클라이언트가 보낸 요청에 대해 세션이나 쿠키 정보를 별도 보관하지 않습니다. 
그렇기 때문에 한 클라이언트가 여러 요청을 보내든 여러 클라이언트가 각각하나의 요청을 보내든 개별적으로 처리합니다. 
이렇게 구성된 서비스는 서버가 불필요한 정보를 관리하지 않으 므로 비즈니스 로직의 자유도가 높고 설계가 단순합니다.

캐시 가능성
REST는 HTTP 표준을 그대로 사용하므로 HTTP의 캐싱 기능을 적용할 수 있습니다. 
이 기능을 이용하 기 위해서는 응답과 요청이 모두 캐싱 가능한지(Cachealle) 명시가 필요하며, 
캐싱이 가능한 경우 클 라이언트에서 캐시에 저장해두고 같은 요청에 대해서는 해당 데이터를 가져다 사용합니다. 
이 기능을 사 용하면 서버의 트랜잭션 부하가 줄이 효율적이며 사용자 입장에서 성능이 개선됩니다.

레이어 시스템
REST 서버는 네트워크 상의 여러 계층으로 구성될 수 있습니다(Layered System). 
그러나 서버의 복 잡도와 관계없이 클라이언트는 서버와 연결되는 포인트만 알면 됩니다.

클라이언트-서버 아키텍처
REST 서버는 API를 제공하고 클라이인트는 사용자 정보를 관리하는 구조로 분리해 설계합니다. 
이 구 성은 서로에 대한 의존성을 낮추는 기능을 합니다.

 

REST의 URI 설계 규칙

URL 규칙.

URI의 마지막에는 '/'를 포함하지 않습니다.
• 옳은 예) http://localhost.com/product
• 잘못된 예) http:/flocalhost.com/product/

언더바(_)는 사용하지 않습니다. 대신 하이픈(-)을 이용합니다.
• 하이픈은 리소스의 이름이 길어지면 사용합니다.
• 옳은 예) http://localhost.com/provider-company-name
• 잘못된 예) http://locahost.com/provider_company_name

URL에는 행위(동사)가 아닌 결과(명사)를 포함합니다.
• 옳은 예) http://localhost.com/product/123
• 잘못된 예) http://localhost.com/delete-product/123
• 행위는 HTTP 메서드로 표현할 수 있어야 합니다.

URI는 소문자로 작성해야 합니다.
• URI 리소스 경로에는 대문자 사용을 피하는 것이 좋습니다.
• 일부 웹 서버의 운영체제는 리소스 경로 부분의 대소문자를 다른 문자로 인식하기 때문입니다. 이러한 이유로 RFC
3986은 UR 문법 형식을 정의하고 있는데, 호스트의 구성요소를 제외하고 UR의 대소문자를 구분해서 정의하고 있 습니다.

파일의 확장자는 URI에 포함하지 않습니다.
• HTTP에서 제공하는 Accept 헤더를 사용하는 것이 좋습니다.