अपाचे टेपेस्ट्री - वास्तुकला
टेपेस्ट्री यथासंभव जावा की उपलब्ध सुविधाओं का उपयोग करने की कोशिश करता है। उदाहरण के लिए, सभी टेपेस्ट्री पेज केवल पीओजेओ हैं। यह आवेदन लिखने के लिए किसी भी कस्टम इंटरफेस या बेस क्लास को लागू नहीं करता है। इसके बजाय, यह सुविधाओं को प्रदान करने के लिए एनोटेशन (एक जावा वर्ग की कार्यक्षमता को बढ़ाने के लिए एक हल्का वजन विकल्प) का उपयोग करता है। यह युद्ध-परीक्षण पर आधारित हैJava Servlet APIऔर एक सर्वलेट फ़िल्टर के रूप में कार्यान्वित किया जाता है। यह वेब एप्लिकेशन को एक नया आयाम प्रदान करता है और प्रोग्रामिंग काफी सरल, लचीली, समझने योग्य और मजबूत है।
कार्यप्रवाह
जब टेपेस्ट्री पेज का अनुरोध किया जाता है, तो कार्रवाई के अनुक्रम पर चर्चा करते हैं।
Step 1 - Java Servletपेज अनुरोध प्राप्त करता है। यह जावा सर्वलेट इस तरह से कॉन्फ़िगर किया गया है कि आने वाले अनुरोध को टेपेस्ट्री में भेज दिया जाएगा। विन्यास में किया जाता हैweb.xmlजैसा कि निम्नलिखित कार्यक्रम में निर्दिष्ट किया गया है। फ़िल्टर और फ़िल्टर मैपिंग टैग टेपेस्ट्री फ़िल्टर के सभी अनुरोध को पुनर्निर्देशित करता है ।
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd">
<web-app>
<display-name>My Tapestry Application</display-name>
<context-param>
<param-name>tapestry.app-package</param-name>
<param-value>org.example.myapp</param-value>
</context-param>
<filter>
<filter-name>app</filter-name>
<filter-class>org.apache.tapestry5.TapestryFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>app</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
Step 2 - Tapestry Filter कॉल करता है HttpServletRequestHandler इसके द्वारा सेवा Service() तरीका।
Step 3 - HttpServletRequestHandler अनुरोध और प्रतिक्रिया को संग्रहीत करता है RequestGlobals। यह रिक्वेस्ट और रिस्पांस ऑब्जेक्ट के रूप में रिक्वेस्ट और रिस्पांस को भी लपेटता है और रिक्वेस्टहैंडलर को भेजता है।
Step 4 - RequestHandler के शीर्ष पर एक अमूर्त है HttpServletRequestसर्वलेट एपीआई की। टेपेस्ट्री की मुख्य विशेषता में से कुछ में किया जाता हैRequestHandlerअनुभाग। टेपेस्ट्री की सुविधा को रिक्वेस्टहैंडलर में फ़िल्टर लिखकर बढ़ाया जा सकता है। RequestHandler कई बिल्ड-इन फिल्टर प्रदान करता है, जिसमें शामिल हैं -
CheckForUpdates Filter- लाइव क्लास रीलोडिंग के लिए जिम्मेदार। यह फ़िल्टर परिवर्तनों के लिए जावा कक्षाओं की जाँच करता है और आवश्यकतानुसार आवेदन को अद्यतन करता है।
Localization Filter - उपयोगकर्ता के स्थान की पहचान करें और आवेदन के लिए स्थानीयकरण समर्थन प्रदान करें।
StaticFiles Filter- स्थिर अनुरोध को पहचानें और प्रक्रिया को निरस्त करें। एक बार प्रक्रिया समाप्त हो जाने पर, जावा सर्वलेट अनुरोध को नियंत्रित और संसाधित करता है।
Error Filter - अनियोजित अपवाद को पकड़ता है और अपवाद रिपोर्ट पृष्ठ प्रस्तुत करता है।
रिक्वेस्टहैंडलर भी अनुरोध को संशोधित करता है और अनुरोध करता है और रिक्वेस्ट करता है।
Step 5 - MasterDispatcherकई प्रेषणकर्ताओं को एक विशिष्ट आदेश देकर पृष्ठ को रेंडर करने के लिए जिम्मेदार है। MasterDispatcher द्वारा बुलाए गए चार-मुख्य प्रेषण इस प्रकार हैं -
RootPath Dispatcher - यह अनुरोध के रूट पथ "/" को पहचानता है और स्टार्ट पेज के समान है।
Asset Dispatcher - इसने url पैटर्न / परिसंपत्तियों / की जाँच करके संपत्ति (जावा संपत्ति) के अनुरोध को मान्यता दी और अनुरोधित परिसंपत्तियों को बाइट धाराओं के रूप में भेजा।
PageRender Dispatcher- टेपेस्ट्री संचालन का थोक पेजरेंडर डिस्पैचर और अगले डिस्पैचर घटक डिस्पैचर में किया जाता है। यह प्रेषणकर्ता उस अनुरोध के विशेष पृष्ठ और उसके सक्रियण संदर्भ (अतिरिक्त जानकारी) को पहचानता है। यह तब उस विशेष पेज को प्रस्तुत करता है और क्लाइंट को भेजता है। उदाहरण के लिए, यदि अनुरोध url / उत्पाद / 12123434 है, तो डिस्पैचर यह जांच करेगा कि नाम उत्पाद / 12123434 के साथ कोई भी वर्ग उपलब्ध है या नहीं। यदि पाया जाता है, तो यह उत्पाद / 12123434 वर्ग को कॉल करता है, प्रतिक्रिया उत्पन्न करता है और इसे क्लाइंट को भेजता है। यदि नहीं, तो यह उत्पाद वर्ग के लिए जाँच करता है। यदि पाया जाता है, तो यह 121234434 अतिरिक्त जानकारी के साथ उत्पाद वर्ग कहता है, प्रतिक्रिया उत्पन्न करता है और ग्राहक को भेजता है। इस अतिरिक्त जानकारी को एक्टिवेशन कॉन्सेप्ट कहा जाता है। यदि कोई वर्ग नहीं मिला है, तो यह घटक डिस्पैचर के लिए अनुरोध को आगे बढ़ाता है।
Component Dispatcher- कंपोनेंट डिस्पैचर पृष्ठ के URL को पैटर्न के साथ मेल खाता है - / <class_name> / <Components_id>: <event_type> / <activate_context>। उदाहरण के लिए, उत्पाद / ग्रिड: सॉर्ट / एएससी उत्पाद वर्ग, ग्रिड घटक, सॉर्टवेंट प्रकार और एसीसी सक्रियण संदर्भ का प्रतिनिधित्व करता है। यहां, Event_type वैकल्पिक है और यदि कोई भी प्रदान नहीं किया गया है, तो डिफ़ॉल्ट ईवेंट प्रकार कार्रवाई ट्रिगर हो जाएगी। आमतौर पर, घटक डिस्पैचर की प्रतिक्रिया क्लाइंट को रीडायरेक्ट भेजने के लिए होती है। अधिकतर, रीडायरेक्ट अगले अनुरोध में पेजरेंडर डिस्पैचर से मेल खाएगा और क्लाइंट को उचित जवाब भेजा जाएगा।