이전글 : 

2020/04/23 - [NETWORK] - REST 란?

 

REST 란?

▶ REST란? - Representational State Transfer의 약자 - HTTP URI(Uniform Resource Identifier)를 통해 자원(Resource)을 명시하고, HTTP Method(POST, GET, PUT, DELETE)를 통해 해당 자원에 대한 CRUD Operat..

programacion.tistory.com

 

▶ REST API 이란? 

 - REST기반으로 서비스 API를 구현한 것

 

▶ REST API 특징

 - REST 기반으로 시스템을 분산해 확장성과 재사용성을 높여 유지보수 및 운용을 편리하게 할 수 있다.

 - REST는 HTTP 표준을 기반으로 구현하므로, HTTP를 지원하는 프로그램 언어로 클라이언트, 서버를 구현할 수 있다.

 - 즉, REST API를 제작하면 델파이 클라이언트 뿐 아니라, 자바, C#, 웹 등을 이용해 클라이언트를 제작할 수 있다.

 

▶ REST API 설계 기본 규칙

※ 참고

도큐먼트 : 객체 인스턴스나 데이터베이스 레코드와 유사한 개념
컬렉션 : 서버에서 관리하는 디렉터리라는 리소스
스토어 : 클라이언트에서 관리하는 리소스 저장소

 - URI는 정보의 자원을 표현

   resource는 동사보다는 명사를, 대문자보다는 소문자를 사용한다.
   resource의 도큐먼트 이름으로는 단수 명사를 사용해야 한다.
   resource의 컬렉션 이름으로는 복수 명사를 사용해야 한다.
   resource의 스토어 이름으로는 복수 명사를 사용해야 한다

 - 자원에 대한 행위는 HTTP Method(GET, PUT, POST, DELETE 등)로 표현

   URI에 HTTP Method가 들어가면 안된다.
   URI에 행위에 대한 동사 표현이 들어가면 안된다.(즉, CRUD 기능을 나타내는 것은 URI에 사용하지 않는다.)
   경로 부분 중 변하는 부분은 유일한 값으로 대체한다.

 

▶ REST API 설계 규칙

 - 

 

 예시

 

▶ RESTful 이란? 

 - 레스트풀은 일반적으로 REST라는 아키텍처를 구현하는 웹 서비스를 나타내기 위해 사용되는 용어이다.

 - 레스트풀은 REST를 REST답게 쓰기 위한 방법으로, REST 원리를 따르는 시스템을 RESTful이란 용어로 지칭된다.

 

RESTful 목적

 - 이해하기 쉽고 사용하기 쉬운 REST API를 만드는 것

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

 

※ 응답상태코드

1xx : 전송 프로토콜 수준의 정보 교환
2xx : 클라어인트 요청이 성공적으로 수행됨
3xx : 클라이언트는 요청을 완료하기 위해 추가적인 행동을 취해야 함
4xx : 클라이언트의 잘못된 요청
5xx : 서버쪽 오류로 인한 상태코드

 

* 추후 추가 예정 

 

 

참고 :

https://www.a-mean-blog.com/ko/blog/%ED%86%A0%EB%A7%89%EA%B8%80/_/REST%EC%99%80-RESTful-API

https://gmlwjd9405.github.io/2018/09/21/rest-and-restful.html 

'* NETWORK' 카테고리의 다른 글

REST 란?  (0) 2020.04.23
웹소켓(WebSocket)이란?  (0) 2020.04.20
포트포워딩 이란?  (0) 2020.04.17

오트밀이 좋다고 해서 구입했는데 ..
너무나 맛이 없어서 뭐가없나 찾아보던중 찾은
레시피!!
(너무간단해서 요리라고하기 부끄럽)

 

** 준비물
오트밀, 견과류, 올리고당(꿀,쌀엿 대체가능),
시나몬가루(선택사항)

저는 오트밀 8스푼, 올리고당 8스푼 했지만..
단거를 안좋아하시면 덜 넣으세요! 6스푼 추천!
꿀넣으시면 건강식이라고 해도 되겠죠?

우선 크랜베리 먼저 숑숑 넣규
남은 견과류들은 잘게 부셔서 넣습니다!

팁* 아닌 팁을 드리자면 일회용봉투에 견과류 넣어서 칼뒤꿈치로 쾅쾅 고.

올리고당이랑 마구 섞어줍니다
시나몬가루도 같이 섞섞

중불로 천천히 타지않게 볶아줍니다!


실리콘 얼음틀에 넣어줬어요 저는
그냥 아무 통에 담아서 식혀주시면 끝!
(참..사진..참 못찍네)

좀 더 노력하는 블로거가 되야지!

안뇽😁

▶ REST란?

 - Representational State Transfer의 약자로 소프트웨어 프로그램 개발의 아키텍처의 한 형식.

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

HTTP 프로토콜을 이용하기 때문에 URL(route)를 통해 자원을 특정짓고 HTTP Verbs를 통해 할일(CRUD)을 지정합니다. 또한 JSON 혹은 XML를 통해 데이터를 주고 받는 것이 일반적입니다.

 CRUD Operation

  - Create : 생성(POST)
  - Read : 조회(GET)
  - Update : 수정(PUT)
  - Delete : 삭제(DELETE)
  - HEAD: header 정보 조회(HEAD)

 

▶ 장단점

 - 장점

1) HTTP 프로토콜의 인프라를 그대로 사용하므로 REST API 사용을 위한 별도의 인프라를 구출할 필요가 없다.
2) HTTP 프로토콜의 표준을 최대한 활용하여 여러 추가적인 장점을 함께 가져갈 수 있게 해 준다.
3) HTTP 표준 프로토콜에 따르는 모든 플랫폼에서 사용이 가능하다.
4) Hypermedia API의 기본을 충실히 지키면서 범용성을 보장한다.
5) REST API 메시지가 의도하는 바를 명확하게 나타내므로 의도하는 바를 쉽게 파악할 수 있다.
6) 여러 가지 서비스 디자인에서 생길 수 있는 문제를 최소화한다.
7) 서버와 클라이언트의 역할을 명확하게 분리한다.

 - 단점

1) 표준이 존재하지 않는다.
2) 사용할 수 있는 메서드가 4가지 밖에 없다.
2-1) HTTP Method 형태가 제한적이다.
3) 브라우저를 통해 테스트할 일이 많은 서비스라면 쉽게 고칠 수 있는 URL보다 Header 값이 왠지 더 어렵게 느껴진다.
4) 구형 브라우저가 아직 제대로 지원해주지 못하는 부분이 존재한다.
4-1) PUT, DELETE를 사용하지 못하는 점
4-2) pushState를 지원하지 않는 점

 

▶ 구성요소

 - 자원(Resource) : URI

   → 모든 자원에 고유한 ID가 존재하고, 이 자원은 Server에 존재한다.
   → 자원을 구별하는 ID는 ‘/groups/:group_id’와 같은 HTTP URI 다.
   → Client는 URI를 이용해서 자원을 지정하고 해당 자원의 상태(정보)에 대한 조작을 Server에 요청한다.

 - 행위(Verb) : HTTP Method

  → HTTP 프로토콜의 Method를 사용한다.
  → HTTP 프로토콜은 GET, POST, PUT, DELETE 와 같은 메서드를 제공한다.

 - 표현(Representation of Resource)

  → Client가 자원의 상태(정보)에 대한 조작을 요청하면 Server는 이에 적절한 응답(Representation)을 보낸다.
  → REST에서 하나의 자원은 JSON, XML, TEXT, RSS 등 여러 형태의 Representation으로 나타내어 질 수 있다.
  → JSON 혹은 XML를 통해 데이터를 주고 받는 것이 일반적이다.

 

▶ 특징

 - Server/Client(서버/클라이언트 구조)

 - Stateless(무상태)

 - Cacheable(캐시 처리 가능)

 - Layered System(계층화)

 - Code-On-Demand(optional)

 - Uniform Interface(인터페이스 일관성)

 

 

이어지는 글 :

2020/04/28 - [NETWORK] - REST API 란? RESTful 이란?

 

REST API 란? RESTful 이란?

2020/04/23 - [NETWORK] - REST 란? REST 란? ▶ REST란? - Representational State Transfer의 약자 - HTTP URI(Uniform Resource Identifier)를 통해 자원(Resource)을 명시하고, HTTP Method(POST, GET, PUT, D..

programacion.tistory.com

 

 

* 참고 :

https://www.a-mean-blog.com/ko/blog/%ED%86%A0%EB%A7%89%EA%B8%80/_/REST%EC%99%80-RESTful-API

https://gmlwjd9405.github.io/2018/09/21/rest-and-restful.html 

'* NETWORK' 카테고리의 다른 글

REST API 란? RESTful 이란?  (0) 2020.04.28
웹소켓(WebSocket)이란?  (0) 2020.04.20
포트포워딩 이란?  (0) 2020.04.17

교촌 허니콤보 & 치즈볼(퐁듀)
세상맛있네 치즈볼😍

'* 소소한 일상 > 냠냠 먹블' 카테고리의 다른 글

보양식  (0) 2020.04.16
호우호우!  (0) 2020.04.14

* 방화벽이란?

 - 방화벽(firewall)은 미리 정의된 보안 규칙에 기반한, 들어오고 나가는 네트워크 트래픽을 모니터링하고 제어하는 네트워크 보안 시스템이다. 방화벽은 일반적으로 신뢰할 수 있는 내부 네트워크, 신뢰할 수 없는 외부 네트워크(예: 인터넷) 간의 장벽을 구성한다. 서로 다른 네트워크를 지나는 데이터를 허용하거나 거부하거나 검열, 수정하는 하드웨어 소프트웨어 장치이다.

출처: 위키백과

 

CentOS 8 환경

▶ 설치

yum install firewalld

y 입력 후 

완료!

▶ 시작 / 중지 / 재시작

systemctl start firewalld	//시작
systemctl enable firewalld	//중지
firewall-cmd --reload		//재시작

설정파일 확인

cd /usr/lib/firewalld/zones

해당 위치의 .xml 파일들에서 기본 설정을 확인할 수 있다.

시스템 개별 설정은 /etc/firewalld 에 위치한 firewalld.conf를 이용해 설정 가능하다.

DefaultZone=public이 기본으로 지정되어 있다. 수정 시 firewalld 재시작이 필요하다.

사용자가 설정한 zone정보는 /etc/firewalld/zones 에 위치한 public.xml 파일에서 확인 가능하다.


▶서비스 추가 / 삭제

firewall-cmd --permanent --zone=public --add-service=http		//추가
firewall-cmd --permanent --zone=public --remove-service=http	//삭제

 

▶포트 추가 / 삭제

firewall-cmd --permanent --zone=public --add-port=80/tcp		//추가
firewall-cmd --permanent --zone=public --add-port=8080-8090/tcp	//추가
firewall-cmd --permanent --zone=public --remove-port=80/tcp		//삭제

 

▶IP 지정 추가

firewall-cmd --permanent --zone=public --add-source=xxx.xx.xx.xx/xx --add-port=22/tcp	//추가

 

* 변경 후 반드시 재시작 firewall-cmd --reload

 

▶확인

firewall-cmd --zone=public --list-all

+ Recent posts