CherryPy-웹 서비스
웹 서비스는 개방형 프로토콜 및 표준을 포함하는 애플리케이션 또는 시스템 간의 데이터 교환을 지원하는 웹 기반 구성 요소 집합입니다. 웹에서 게시, 사용 및 찾을 수 있습니다.
웹 서비스는 RWS (RESTfUL Web Service), WSDL, SOAP 등과 같은 다양한 유형입니다.
REST — 표현 상태 전송
원격 프로 시저를 호출하는 대신 상태를 조작하는 데 사용할 수있는 클라이언트에서 서버로 상태를 전송하는 원격 액세스 프로토콜 유형입니다.
특정 인코딩이나 구조 및 유용한 오류 메시지를 반환하는 방법을 정의하지 않습니다.
HTTP "동사"를 사용하여 상태 전송 작업을 수행합니다.
리소스는 URL을 사용하여 고유하게 식별됩니다.
API가 아니라 API 전송 계층입니다.
REST는 네트워크에서 리소스 명명법을 유지하고 이러한 리소스에 대한 작업을 수행하기위한 통합 메커니즘을 제공합니다. 각 리소스는 하나 이상의 식별자로 식별됩니다. REST 인프라가 HTTP 기반으로 구현 된 경우 이러한 식별자는Uniform Resource Identifiers (URIs).
다음은 URI 세트의 두 가지 일반적인 하위 집합입니다-
부분 집합 | 전체 형식 | 예 |
---|---|---|
URL | 유니폼 리소스 로케이터 | http://www.gmail.com/ |
항아리 | 균일 한 리소스 이름 | urn : isbn : 0-201-71088-9 urn : uuid : 13e8cf26-2a25-11db-8693-000ae4ea7d46 |
CherryPy 아키텍처의 구현을 이해하기 전에 CherryPy의 아키텍처에 초점을 맞 춥니 다.
CherryPy는 다음 세 가지 구성 요소를 포함합니다.
cherrypy.engine − 프로세스 시작 / 해체 및 이벤트 처리를 제어합니다.
cherrypy.server − WSGI 또는 HTTP 서버를 설정하고 제어합니다.
cherrypy.tools − HTTP 요청 처리와 직교하는 유틸리티 도구 상자.
CherryPy를 통한 REST 인터페이스
RESTful 웹 서비스는 다음의 도움으로 CherryPy 아키텍처의 각 섹션을 구현합니다.
- Authentication
- Authorization
- Structure
- Encapsulation
- 오류 처리
입증
인증은 우리가 상호 작용하는 사용자를 확인하는 데 도움이됩니다. CherryPy에는 각 인증 방법을 처리하는 도구가 포함되어 있습니다.
def authenticate():
if not hasattr(cherrypy.request, 'user') or cherrypy.request.user is None:
# < Do stuff to look up your users >
cherrypy.request.authorized = False # This only authenticates.
Authz must be handled separately.
cherrypy.request.unauthorized_reasons = []
cherrypy.request.authorization_queries = []
cherrypy.tools.authenticate = \
cherrypy.Tool('before_handler', authenticate, priority=10)
위의 함수 authenticate ()는 클라이언트 또는 사용자의 존재를 확인하는 데 도움이됩니다. 기본 제공 도구는 프로세스를 체계적으로 완료하는 데 도움이됩니다.
권한 부여
권한 부여는 URI를 통해 프로세스의 온 전성을 유지하는 데 도움이됩니다. 이 프로세스는 사용자 토큰 리드별로 개체를 변형하는데도 도움이됩니다.
def authorize_all():
cherrypy.request.authorized = 'authorize_all'
cherrypy.tools.authorize_all = cherrypy.Tool('before_handler', authorize_all, priority=11)
def is_authorized():
if not cherrypy.request.authorized:
raise cherrypy.HTTPError("403 Forbidden",
','.join(cherrypy.request.unauthorized_reasons))
cherrypy.tools.is_authorized = cherrypy.Tool('before_handler', is_authorized,
priority = 49)
cherrypy.config.update({
'tools.is_authorized.on': True,
'tools.authorize_all.on': True
})
내장 된 권한 부여 도구는 이전 예에서 언급했듯이 체계적인 방식으로 루틴을 처리하는 데 도움이됩니다.
구조
API 구조를 유지하면 응용 프로그램의 URI 매핑 작업 부하를 줄이는 데 도움이됩니다. 항상 API를 검색 가능하고 깔끔하게 유지해야합니다. CherryPy 프레임 워크 용 API의 기본 구조는 다음과 같아야합니다.
- 계정 및 사용자
- Autoresponder
- Contact
- File
- Folder
- 목록 및 필드
- 메시지 및 배치
캡슐화
캡슐화는 가볍고 사람이 읽을 수 있고 다양한 클라이언트가 액세스 할 수있는 API를 만드는 데 도움이됩니다. 생성, 검색, 업데이트 및 삭제와 함께 항목 목록에는 API 캡슐화가 필요합니다.
오류 처리
이 프로세스는 API가 특정 본능에서 실행되지 않는 경우 오류를 관리합니다. 예를 들어 400은 잘못된 요청이고 403은 권한이없는 요청입니다.
예
데이터베이스, 유효성 검사 또는 응용 프로그램 오류에 대한 예로 다음을 고려하십시오.
import cherrypy
import json
def error_page_default(status, message, traceback, version):
ret = {
'status': status,
'version': version,
'message': [message],
'traceback': traceback
}
return json.dumps(ret)
class Root:
_cp_config = {'error_page.default': error_page_default}
@cherrypy.expose
def index(self):
raise cherrypy.HTTPError(500, "Internal Sever Error")
cherrypy.quickstart(Root())
위의 코드는 다음 출력을 생성합니다.
접근 도구가 내장되어있어 CherryPy를 통해 API (Application Programming Interface) 관리가 용이합니다.
HTTP 방법
리소스에서 작동하는 HTTP 메소드 목록은 다음과 같습니다.
S. 아니 | HTTP 방법 및 작동 |
---|---|
1. | HEAD 리소스 메타 데이터를 검색합니다. |
2. | GET 리소스 메타 데이터 및 콘텐츠를 검색합니다. |
삼. | POST 요청 본문에 포함 된 데이터를 사용하여 새 리소스를 만들도록 서버에 요청합니다. |
4. | PUT 기존 리소스를 요청 본문에 포함 된 리소스로 바꾸도록 서버에 요청합니다. |
5. | DELETE 해당 URI로 식별되는 리소스를 제거하도록 서버에 요청합니다. |
6. | OPTIONS 전역 적으로 또는 구체적으로 리소스에 대한 기능에 대한 세부 정보를 반환하도록 서버에 요청합니다. |
아톰 게시 프로토콜 (APP)
APP는 웹 리소스를 게시하고 편집 할 수 있도록 HTTP 위에 애플리케이션 수준 프로토콜로 Atom 커뮤니티에서 생성되었습니다. APP 서버와 클라이언트 간의 메시지 단위는 Atom XML 문서 형식을 기반으로합니다.
Atom Publishing Protocol은 HTTP 및 해당 메커니즘과 Atom XML 문서 형식을 메시지 단위로 사용하여 APP 서비스와 사용자 에이전트 간의 작업 집합을 정의합니다.
APP는 먼저 APP 서비스에서 제공하는 다양한 컬렉션의 URI를 사용자 에이전트에 제공하는 서비스 문서를 정의합니다.
예
APP 작동 방식을 보여주는 예를 들어 보겠습니다.
<?xml version = "1.0" encoding = "UTF-8"?>
<service xmlns = "http://purl.org/atom/app#" xmlns:atom = "http://www.w3.org/2005/Atom">
<workspace>
<collection href = "http://host/service/atompub/album/">
<atom:title> Albums</atom:title>
<categories fixed = "yes">
<atom:category term = "friends" />
</categories>
</collection>
<collection href = "http://host/service/atompub/film/">
<atom:title>Films</atom:title>
<accept>image/png,image/jpeg</accept>
</collection>
</workspace>
</service>
APP는 다음 표에 설명 된대로 HTTP 메서드를 사용하여 컬렉션의 구성원 또는 컬렉션 자체에 대해 기본 CRUD 작업을 수행하는 방법을 지정합니다.
조작 | HTTP 방식 | 상태 코드 | 함유량 |
---|---|---|---|
검색 | 가져 오기 | 200 | 자원을 나타내는 Atom 항목 |
창조하다 | 게시하다 | 201 | Location 및 Content-Location 헤더를 통해 새로 생성 된 리소스의 URI |
최신 정보 | 놓다 | 200 | 자원을 나타내는 Atom 항목 |
지우다 | 지우다 | 200 | 없음 |