REST, REST API, RESTful이란?

미어캣의 개발일지·2023년 6월 29일
0

📚 REST

📕 REST란?

자원을 이름으로 구분하여 해당 자원의 상태주고받는 모든 것

  • HTTP라는 프로토콜을 이용하여 Web에서 제공하는 모든 자원을 가리킬 수 있는 고유한 주소(URI)를 이용해서 HTTP Method를 통해 작업(CRUD)을 처리하는 방식

자원(resource)의 표현(representation)에 의한 상태 전달

  1. 자원(resource)의 표현(representation)

    • 자원: 해당 소프트웨어가 관리하는 모든 것
      ex) 문서, 그림, 데이터, 해당 소프트웨어 자체 등
    • 자원의 표현: 그 자원을 표현하기 위한 이름
      ex) DB의 학생 정보가 자원일 때, ‘students’를 자원의 표현으로 정함.
  2. 상태(정보) 전달

    • 데이터가 요청되어지는 시점에서 자원의 상태(정보)를 전달.
    • JSON 혹은 XML를 통해 데이터를 주고 받는 것이 일반적.


📕 REST의 개념

HTTP URI를 통해 자원(resource)을 명시하고, HTTP Method(POST, GET, PUT, DELETE)를 통해 해당 자원에 대한 CRUD Operation을 적용하는 것을 의미

  • 웹 사이트의 이미지, 텍스트, DB 내용 등의 모든 자원에 고유한 ID인 HTTP URI를 부여
  • CRUD Operation
    • Create : 생성(POST)
    • Read : 조회(GET)
    • Update : 수정(PUT)
    • Delete : 삭제(DELETE)
    • HEAD: header 정보 조회(HEAD)


📕 REST의 장단점

📖 장점

  • HTTP 프로토콜의 인프라를 그대로 사용하므로 REST API 사용을 위한 별도의 인프라구축할 필요가 없다.
  • HTTP 표준 프로토콜에 따르는 모든 플랫폼에서 사용 가능.
  • REST API 메시지가 의도하는 바를 명확하게 나타내므로 의도를 쉽게 파악할 수 있다.
  • 서버와 클라이언트의 역할을 명확하게 분리

📖 단점

  • 표준이 존재하지 않음
  • 사용할 수 있는 메소드가 4가지 밖에 없다.



📚 REST API

📕 REST API란?

REST 기반으로 서비스를 API를 구현한 것, OpenAPI는 대부분 REST API를 제공

  • API(Application Program Interface)란?
    • 데이터와 기능의 집합을 제공하여 컴퓨터 프로그램간 상호작용을 촉진, 정보 교환 가능하도록 하는 것


📕 REST API 특징

  • 사내 시스템들도 REST 기반으로 시스템을 분산확장성재사용성을 높여 유지보수 및 운용을 편리하게 할 수 있다.
  • REST는 HTTP 표준을 기반으로 구현하므로, HTTP를 지원하는 프로그램 언어로 클라이언트, 서버를 구현할 수 있다.
  • 즉, REST API를 제작하면 델파이 클라이언트 뿐 아니라, 자바, C#, 웹 등을 이용해 클라이언트를 제작할 수 있다.



📚 RESTful

📕 RESTful이란?

REST라는 아키텍처를 구현하는 웹 서비스를 나타내기 위해 사용되는 용어

  • RESTful은 REST를 REST답게 쓰기 위한 방법으로, 누군가가 공식적으로 발표한 것이 아니다.
    즉, REST 원리를 따르는 시스템은 RESTful이란 용어로 지칭


📕 RESTful의 목적

  • 이해하기 쉽고 사용하기 쉬운 REST API를 만드는 것
  • RESTful한 API를 구현하는 근본적인 목적이 성능 향상에 있는 것이 아니라 일관적인 컨벤션을 통한 API의 이해도 및 호환성을 높이는 것이 주 동기이니, 성능이 중요한 상황에서는 굳이 RESTful한 API를 구현할 필요는 없다.


📕 RESTful 하지 못한 경우

  • Ex1) CRUD 기능을 모두 POST로만 처리하는 API
  • Ex2) route에 resource, id 외의 정보가 들어가는 경우(/students/updateName)



📚 참조

https://appmaster.io/ko/blog/rest-apiran-mueosimyeo-dareun-yuhyeonggwa-eoddeohge-dareungayo
https://gmlwjd9405.github.io/2018/09/21/rest-and-restful.html
https://sidepower.tistory.com/408

profile
이게 왜 안되지? 이게 왜 되지?

0개의 댓글