चेरीपी - वेब सेवाएँ

एक वेब सेवा वेब-आधारित घटकों का एक सेट है जो एप्लिकेशन या सिस्टम के बीच डेटा के आदान-प्रदान में मदद करता है जिसमें खुले प्रोटोकॉल और मानक भी शामिल हैं। यह वेब पर प्रकाशित, उपयोग और पाया जा सकता है।

वेब सेवाएँ विभिन्न प्रकार की हैं जैसे RWS (RESTfUL Web Service), WSDL, SOAP और कई अन्य।

बाकी - प्रतिनिधि राज्य स्थानांतरण

एक प्रकार का रिमोट एक्सेस प्रोटोकॉल, जो क्लाइंट से सर्वर में राज्य को स्थानांतरित करता है, जिसका उपयोग दूरस्थ प्रक्रियाओं को कॉल करने के बजाय राज्य में हेरफेर करने के लिए किया जा सकता है।

  • किसी विशिष्ट एन्कोडिंग या संरचना और उपयोगी त्रुटि संदेशों को वापस करने के तरीकों को परिभाषित नहीं करता है।

  • राज्य हस्तांतरण संचालन करने के लिए HTTP "क्रिया" का उपयोग करता है।

  • URL का उपयोग करते हुए संसाधनों को विशिष्ट रूप से पहचाना जाता है।

  • यह एक एपीआई नहीं है, बल्कि एक एपीआई परिवहन परत है।

REST एक नेटवर्क पर संसाधनों के नामकरण को बनाए रखता है और इन संसाधनों पर संचालन करने के लिए एकीकृत तंत्र प्रदान करता है। प्रत्येक संसाधन की पहचान कम से कम एक पहचानकर्ता द्वारा की जाती है। यदि HTTP के आधार के साथ REST इन्फ्रास्ट्रक्चर लागू किया जाता है, तो इन पहचानकर्ताओं को कहा जाता हैUniform Resource Identifiers (URIs)

URI सेट के दो सामान्य उपसमूह निम्नलिखित हैं -

सबसेट पूर्ण प्रपत्र उदाहरण
यूआरएल यूनिफ़ॉर्म रिसोर्स लोकेटर http://www.gmail.com/
URN यूनिफ़ॉर्म रिसोर्स नाम कलश: isbn: 0-201-71088-9 urn: uuid: 13e8cf26-2a25-11db-8693-000ae4ea7d46

चेरीपी आर्किटेक्चर के कार्यान्वयन को समझने से पहले, आइए चेरीपी वास्तुकला पर ध्यान दें।

चेरीपी में निम्नलिखित तीन घटक शामिल हैं -

  • cherrypy.engine - यह प्रक्रिया स्टार्टअप / फाड़ और घटना से निपटने को नियंत्रित करता है।

  • cherrypy.server - यह WSGI या HTTP सर्वर को कॉन्फ़िगर और नियंत्रित करता है।

  • cherrypy.tools उपयोगिताओं का एक टूलबॉक्स जो HTTP अनुरोध को संसाधित करने के लिए रूढ़िवादी है।

चेरी इंटरफेस के माध्यम से अन्य इंटरफेस

RESTful वेब सेवा चेरीपी आर्किटेक्चर के प्रत्येक भाग को निम्नलिखित की मदद से लागू करती है -

  • Authentication
  • Authorization
  • Structure
  • Encapsulation
  • गलती संभालना

प्रमाणीकरण

प्रमाणीकरण उन उपयोगकर्ताओं को मान्य करने में मदद करता है जिनके साथ हम बातचीत कर रहे हैं। चेरीप्री में प्रत्येक प्रमाणीकरण विधि को संभालने के लिए उपकरण शामिल हैं।

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)

उपरोक्त फ़ंक्शन प्रमाणित () क्लाइंट या उपयोगकर्ताओं के अस्तित्व को मान्य करने में मदद करेगा। अंतर्निहित उपकरण प्रक्रिया को व्यवस्थित तरीके से पूरा करने में मदद करते हैं।

प्राधिकरण

प्राधिकरण 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
})

प्राधिकरण के अंतर्निहित उपकरण व्यवस्थित तरीके से दिनचर्या को संभालने में मदद करते हैं, जैसा कि पिछले उदाहरण में बताया गया है।

संरचना

एपीआई की संरचना को बनाए रखने से आवेदन के यूआरआई मानचित्रण के कार्य भार को कम करने में मदद मिलती है। एपीआई को खोज योग्य और साफ रखना हमेशा आवश्यक होता है। चेरी की रूपरेखा के लिए एपीआई की मूल संरचना निम्नलिखित होनी चाहिए -

  • खाते और उपयोगकर्ता
  • Autoresponder
  • Contact
  • File
  • Folder
  • सूची और क्षेत्र
  • संदेश और बैच

कैप्सूलीकरण

एनकैप्सुलेशन एपीआई बनाने में मदद करता है जो हल्के, मानव पठनीय और विभिन्न ग्राहकों के लिए सुलभ है। निर्माण, पुनर्प्राप्ति, अद्यतन और हटाए जाने के साथ वस्तुओं की सूची में एपीआई के एनकैप्सुलेशन की आवश्यकता होती है।

गलती संभालना

यह प्रक्रिया त्रुटियों का प्रबंधन करती है, यदि कोई हो, अगर एपीआई विशेष वृत्ति पर निष्पादित करने में विफल रहता है। उदाहरण के लिए, 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())

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करेगा -

बिल्ट-इन एक्सेस टूल के कारण चेरी के माध्यम से एपीआई (एप्लिकेशन प्रोग्रामिंग इंटरफेस) का प्रबंधन आसान है।

HTTP तरीके

HTTP तरीकों की सूची जो संसाधनों पर काम करती है वे इस प्रकार हैं -

S.No HTTP विधि और संचालन
1।

HEAD

संसाधन मेटाडेटा पुनर्प्राप्त करता है।

2।

GET

संसाधन मेटाडेटा और सामग्री को पुनर्प्राप्त करता है।

3।

POST

अनुरोध शरीर में संलग्न डेटा का उपयोग करके एक नया संसाधन बनाने के लिए सर्वर से अनुरोध करता है।

4।

PUT

अनुरोध निकाय में संलग्न एक मौजूदा संसाधन को बदलने के लिए सर्वर का अनुरोध करता है।

5।

DELETE

सर्वर से उस URI द्वारा पहचाने गए संसाधन को हटाने का अनुरोध करता है।

6।

OPTIONS

सर्वर से अनुरोध है कि वह विश्व स्तर पर या विशेष रूप से किसी संसाधन की क्षमताओं के बारे में विवरण लौटाए।

एटम प्रकाशन प्रोटोकॉल (एपीपी)

एपीपी वेब संसाधनों के प्रकाशन और संपादन की अनुमति देने के लिए HTTP के शीर्ष पर एक अनुप्रयोग-स्तरीय प्रोटोकॉल के रूप में एटम समुदाय से उत्पन्न हुआ है। एक एपीपी सर्वर और क्लाइंट के बीच संदेशों की इकाई एटम एक्सएमएल-दस्तावेज़ प्रारूप पर आधारित है।

एटम पब्लिशिंग प्रोटोकॉल एपीपी सेवा और उपयोगकर्ता-एजेंट के बीच HTTP और इसके तंत्र और एटम एक्सएमएल-दस्तावेज़ प्रारूप का उपयोग करके संदेशों की इकाई के रूप में संचालन के एक सेट को परिभाषित करता है।

एपीपी पहले एक सेवा दस्तावेज को परिभाषित करता है, जो उपयोगकर्ता एजेंट को एपीपी सेवा द्वारा प्रदान किए गए विभिन्न संग्रह के यूआरआई के साथ प्रदान करता है।

उदाहरण

आइए हम एक उदाहरण लेते हैं कि एपीपी कैसे काम करता है -

<?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>

एपीपी निम्नलिखित के रूप में वर्णित HTTP तरीकों का उपयोग करके किसी संग्रह या संग्रह के सदस्य के खिलाफ मूल CRUD संचालन करने के लिए कैसे निर्दिष्ट करता है -

ऑपरेशन HTTP विधि स्थिति का कोड सामग्री
पुन: प्राप्त करें प्राप्त 200 एक एटम प्रविष्टि संसाधन का प्रतिनिधित्व करती है
सृजन करना पद 201 स्थान और सामग्री-स्थान शीर्षकों के माध्यम से नए बनाए गए संसाधन का URI
अपडेट करें डाल 200 एक एटम प्रविष्टि संसाधन का प्रतिनिधित्व करती है
हटाएं हटाएँ 200 कोई नहीं