अपाचे टेपेस्ट्री - त्वरित गाइड

Apache Tapestry जावा में लिखा गया एक ओपन सोर्स वेब फ्रेमवर्क है। यह है एकcomponent based web framework। टेपेस्ट्री घटक जावा वर्ग हैं। उन्हें न तो एक फ्रेमवर्क विशिष्ट बेस क्लास से विरासत में मिला है और न ही एक इंटरफ़ेस का कार्यान्वयन और वे सिर्फ सादे POJOs (पुराने जावा ऑब्जेक्ट्स) हैं।

टेपेस्ट्री द्वारा उपयोग किए जाने वाले जावा की महत्वपूर्ण विशेषता है Annotation। टेपेस्ट्री वेब पेजों का निर्माण एक या एक से अधिक घटकों का उपयोग करके किया जाता है, जिनमें से प्रत्येक में एक्सएमएल आधारित टेम्पलेट और घटक वर्ग होता है जिसे बहुत सारे टेपेस्ट्री एनोटेशन से सजाया जाता है। टेपेस्ट्री एक छोटे, एकल पृष्ठ वेब अनुप्रयोग से लेकर बड़े पैमाने पर सैकड़ों पृष्ठों से मिलकर कुछ भी बना सकती है।

टेपेस्ट्री के लाभ

टेपेस्ट्री द्वारा प्रदान किए गए कुछ लाभ हैं -

  • अत्यधिक स्केलेबल वेब अनुप्रयोग।
  • अनुकूली एपीआई।
  • तेज और परिपक्व ढांचा।
  • लगातार राज्य भंडारण प्रबंधन।
  • नियंत्रण के निर्माण में उलटा।

टेपेस्ट्री की विशेषताएं

टेपेस्ट्री में निम्नलिखित विशेषताएं हैं -

  • लाइव क्लास फिर से लोड करना
  • स्पष्ट और विस्तृत अपवाद रिपोर्टिंग
  • स्थैतिक संरचना, गतिशील व्यवहार।
  • सादा पुराने जावा ऑब्जेक्ट्स (POJOs) का व्यापक उपयोग
  • कोड कम, अधिक वितरित करें।

टेपेस्ट्री क्यों?

पहले से ही जावा में बहुत सारे वेब फ्रेमवर्क जैसे जेएसपी, स्ट्रट्स आदि हैं, फिर, हमें दूसरे फ्रेमवर्क की आवश्यकता क्यों है? आज के अधिकांश जावा वेब फ्रेमवर्क जटिल हैं और इनमें सीखने की अवस्था है। वे पुराने जमाने के हैं और हर अपडेट के लिए संकलन, परीक्षण और तैनाती चक्र की आवश्यकता होती है।

दूसरी ओर, टेपेस्ट्री प्रदान करके वेब एप्लिकेशन प्रोग्रामिंग को एक आधुनिक दृष्टिकोण प्रदान करता है live class reloading। जबकि अन्य चौखटे बहुत सारे इंटरफेस, अमूर्त और आधार वर्ग का परिचय दे रहे हैं, टेपेस्ट्री अभी एनोटेशन का एक छोटा सा सेट पेश करता है और फिर भी समृद्ध AJAX समर्थन के साथ बड़े एप्लिकेशन को लिखने की क्षमता प्रदान करता है।

टेपेस्ट्री यथासंभव जावा की उपलब्ध सुविधाओं का उपयोग करने की कोशिश करता है। उदाहरण के लिए, सभी टेपेस्ट्री पेज केवल पीओजेओ हैं। यह आवेदन लिखने के लिए किसी भी कस्टम इंटरफेस या बेस क्लास को लागू नहीं करता है। इसके बजाय, यह सुविधाओं को प्रदान करने के लिए एनोटेशन (एक जावा वर्ग की कार्यक्षमता को बढ़ाने के लिए एक हल्का वजन विकल्प) का उपयोग करता है। यह युद्ध-परीक्षण पर आधारित है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- टेपेस्ट्री संचालन के थोक पेजरेंडर डिस्पैचर और अगले डिस्पैचर घटक डिस्पैचर में किए जाते हैं। यह प्रेषणकर्ता उस अनुरोध के विशेष पृष्ठ और उसके सक्रियण संदर्भ (अतिरिक्त जानकारी) को पहचानता है। यह तब उस विशेष पेज को प्रस्तुत करता है और क्लाइंट को भेजता है। उदाहरण के लिए, यदि अनुरोध यूआरएल / उत्पाद / 12123434 है, तो डिस्पैचर यह जांच करेगा कि क्या नाम उत्पाद / 12123434 के साथ कोई भी वर्ग उपलब्ध है। यदि पाया जाता है, तो यह उत्पाद / 12123434 वर्ग को कॉल करता है, प्रतिक्रिया उत्पन्न करता है और ग्राहक को भेजता है। यदि नहीं, तो यह उत्पाद वर्ग के लिए जाँच करता है। यदि पाया जाता है, तो यह 121234434 अतिरिक्त जानकारी के साथ उत्पाद वर्ग को कॉल करता है, प्रतिक्रिया उत्पन्न करता है और इसे क्लाइंट को भेजता है। इस अतिरिक्त जानकारी को एक्टिवेशन कॉन्सेप्ट कहा जाता है। यदि कोई वर्ग नहीं पाया जाता है, तो यह घटक डिस्पैचर के लिए अनुरोध करता है।

  • Component Dispatcher- कंपोनेंट डिस्पैचर पृष्ठ के URL को पैटर्न के साथ मेल खाता है - / <class_name> / <Components_id>: <event_type> / <activate_context>। उदाहरण के लिए, / उत्पाद / ग्रिड: सॉर्ट / एएससी उत्पाद वर्ग, ग्रिड घटक, सॉर्टवेंट प्रकार और एसीसी सक्रियण संदर्भ का प्रतिनिधित्व करता है। यहां, event_type वैकल्पिक है और यदि कोई भी प्रदान नहीं किया गया है, तो डिफ़ॉल्ट ईवेंट प्रकार कार्रवाई ट्रिगर हो जाएगी। आमतौर पर, घटक डिस्पैचर की प्रतिक्रिया क्लाइंट को रीडायरेक्ट भेजने के लिए होती है। अधिकतर, रीडायरेक्ट अगले अनुरोध में पेजरेंडर डिस्पैचर से मेल खाएगा और क्लाइंट को उचित जवाब भेजा जाएगा।

इस अध्याय में, हम चर्चा करेंगे कि हमारी मशीन पर टेपेस्ट्री कैसे स्थापित करें।

शर्त

टेपेस्ट्री की एकमात्र निर्भरता है Core Java। किसी तीसरे पक्ष के पुस्तकालय / ढांचे का उपयोग किए बिना टेपेस्ट्री स्वतंत्र रूप से विकसित की जाती है। यहां तक ​​कि टेपेस्ट्री द्वारा उपयोग किए गए IoC पुस्तकालय को खरोंच से विकसित किया गया है। टेपेस्ट्री में लिखे गए वेब एप्लिकेशन को कंसोल से ही बनाया और तैनात किया जा सकता है।

हम प्रयोग कर सकते हैं Maven, Eclipse तथा Jettyविकास के अनुभव को बेहतर बनाने के लिए। मावेन जेट्टी, जावा के डी-फैक्टो डेवलपमेंट सर्वर में एप्लिकेशन को होस्ट करने के लिए त्वरित शुरुआत एप्लिकेशन टेम्पलेट और विकल्प प्रदान करता है। ग्रहण व्यापक परियोजना प्रबंधन सुविधाएँ प्रदान करता है और मावेन के साथ अच्छी तरह से एकीकृत करता है।

एक आदर्श टेपेस्ट्री अनुप्रयोग विकास के लिए निम्नलिखित की आवश्यकता है -

  • जावा 1.6 या बाद का
  • अपाचे मावेन
  • ग्रहण आईडीई
  • जेट्टी सर्वर

मावेन स्थापना को सत्यापित करें

उम्मीद है, आपने मावेन को अपनी मशीन पर स्थापित किया है। मावेन इंस्टॉलेशन को सत्यापित करने के लिए, नीचे दी गई कमांड टाइप करें -

mvn --version

आप नीचे दी गई प्रतिक्रिया देख सकते हैं -

Apache Maven 3.3.9 (bb52d8502b132ec0a5a3f4c09453c07478323dc5; 2015-1110T22:11:47+05:30) 
Maven home: /Users/workspace/maven/apache-maven-3.3.9 
Java version: 1.8.0_92, vendor: Oracle Corporation 
Java home: /Library/Java/JavaVirtualMachines/jdk1.8.0_92.jdk/Contents/Home/jre 
Default locale: en_US, platform encoding: UTF-8 
OS name: "mac os x", version: "10.11.4", arch: "x86_64", family: "mac"

यदि मावेन स्थापित नहीं है, तो मावेन वेबसाइट पर जाकर मावेन के नवीनतम संस्करण को डाउनलोड और इंस्टॉल करें।

टेपेस्ट्री डाउनलोड करें

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

टेपेस्ट्री की स्थापना के बाद, मावेन का उपयोग करके एक नई प्रारंभिक परियोजना बनाएं, जैसा कि नीचे दिखाया गया है -

$ mvn archetype:generate -DarchetypeCatalog=http://tapestry.apache.org

आप नीचे दी गई प्रतिक्रिया देख सकते हैं -

[INFO] Scanning for projects... 
[INFO] 
[INFO] --------------------------------------------------------------------------------- 
[INFO] Building Maven Stub Project (No POM) 1 
[INFO] ---------------------------------------------------------------------------------
[INFO] 
[INFO] >>> maven-archetype-plugin:2.4:generate (default-cli) > 
generatesources @ standalone-pom >>> 
[INFO]  
[INFO] <<< maven-archetype-plugin:2.4:generate (default-cli) 
< generatesources @ standalone-pom <<< 
[INFO] 
[INFO] --- maven-archetype-plugin:2.4:generate (default-cli) @ standalone-pom --- 
[INFO] Generating project in Interactive mode 
[INFO] No archetype defined. Using maven-archetype-quickstart 
(org.apache.maven.archetypes:maven-archetype-quickstart:1.0)

मावेन के सभी कार्यों के निर्माण के बाद, इसे बनाने के लिए archetype चुनें Tapestry 5 QuickStart परियोजना इस प्रकार है -

Choose archetype -

  • https://tapestry.apache.org → org.apache.tapestry: quickstart (टेपेस्ट्री 5 क्विकस्टार्ट प्रोजेक्ट)

  • https://tapestry.apache.org → org.apache.tapestry: टेपेस्ट्री-आर्केथाइप (टेपेस्ट्री 4.1.6 आर्कएप्टाइप)

एक संख्या चुनें या फ़िल्टर लागू करें (प्रारूप: [groupId:] विरूपण साक्ष्य, केस संवेदनशील शामिल हैं): 1

अब आपको एक प्रतिक्रिया मिलेगी कि नीचे क्या दिखाया गया है -

Choose org.apache.tapestry:quickstart version: 
1: 5.0.19
2: 5.1.0.5 
3: 5.2.6 
4: 5.3.7 
5: 5.4.1

क्विकस्टार्ट संस्करण संख्या को निम्नानुसार निकालें -

Choose a number: 5: 5

यहां, क्विकस्टार्ट प्रोजेक्ट विकल्प 5, "5.4.1" के लिए संस्करण लेता है। अब, टेपेस्ट्री आर्कथाइप निम्नलिखित जानकारी को एक-एक करके निम्नानुसार पूछता है -

  • 5.1 groupId - संपत्ति 'groupId' के लिए मान को परिभाषित करें: com.example

  • 5.2 artifactId - संपत्ति 'विरूपण साक्ष्य' के लिए मूल्य निर्धारित करें:: मैप्प

  • 5.3 version - संपत्ति 'संस्करण' के लिए मान को परिभाषित करें: 1.0-SNAPSHOT:

  • 5.4 package name - संपत्ति 'पैकेज' के लिए मूल्य निर्धारित करें: com.example:: com.example.Myapp

अब आपकी स्क्रीन आपसे पुष्टि पूछती है -

संपत्तियों की पुष्टि की पुष्टि करें -

  • groupId - com.example

  • artifactId - माय

  • version - 1.0-स्नैपशॉट

  • package - com.example.Myapp

सभी गुणों को सत्यापित करें और नीचे दिखाए गए विकल्प का उपयोग करके परिवर्तनों की पुष्टि करें -

Y: : Y

आप नीचे दिखाए गए स्क्रीन की तरह देखेंगे।

[INFO] ---------------------------------------------------------------------------------
[INFO] Using following parameters for creating project from Archetype: quickstart:5.4.1 
[INFO] ---------------------------------------------------------------------------------
[INFO] Parameter: groupId, Value: com.example 
[INFO] Parameter: artifactId, Value: Myapp 
[INFO] Parameter: version, Value: 1.0-SNAPSHOT 
[INFO] Parameter: package, Value: com.example.Myapp 
[INFO] Parameter: packageInPathFormat, Value: com/example/Myapp 
[INFO] Parameter: package, Value: com.example.Myapp 
[INFO] Parameter: version, Value: 1.0-SNAPSHOT 
[INFO] Parameter: groupId, Value: com.example 
[INFO] Parameter: artifactId, Value: Myapp 
[WARNING] Don't override file /Users/workspace/tapestry/Myapp/src/test/java 
[WARNING] Don't override file /Users/workspace/tapestry/Myapp/src/main/webapp 
[WARNING] Don't override file /Users/workspace/tapestry/Myapp/src/main/resources/com/
example/Myapp 
[WARNING] Don't override file /Users/workspace/tapestry/Myapp/src/test/resource 
[WARNING] Don't override file /Users/workspace/tapestry/Myapp/src/test/conf 
[WARNING] Don't override file /Users/workspace/tapestry/Myapp/src/site 
[INFO] project created from Archetype in dir: /Users/workspace/tapestry/Myapp 
[INFO] --------------------------------------------------------------------------------- 
[INFO] BUILD SUCCESS 
[INFO] --------------------------------------------------------------------------------- 
[INFO] Total time: 11:28 min 
[INFO] Finished at: 2016-09-14T00:47:23+05:30 
[INFO] Final Memory: 14M/142M 
[INFO] ---------------------------------------------------------------------------------

यहाँ, आपने सफलतापूर्वक टेपेस्ट्री क्विक स्टार्ट प्रोजेक्ट का निर्माण किया है। नए बनाए गए स्थान पर जाएंMyapp निम्नलिखित कमांड के साथ निर्देशिका और कोडिंग शुरू करें।

cd Myapp

अनुप्रयोग चलाएँ

कंकाल परियोजना को चलाने के लिए, निम्नलिखित कमांड का उपयोग करें।

mvn jetty:run -Dtapestry.execution-mode=development

आपको एक स्क्रीन मिलती है,

[INFO] Scanning for projects... 
[INFO] 
[INFO] ---------------------------------------------------------------------------------
[INFO] Building Myapp Tapestry 5 Application 1.0-SNAPSHOT 
[INFO] ---------------------------------------------------------------------------------
........ 
........ 
........ 
Application 'app' (version 1.0-SNAPSHOT-DEV) startup time: 346 ms to build IoC 
Registry, 1,246 ms overall.  
 ______                  __             ____ 
/_  __/__ ____  ___ ___ / /_______ __  / __/ 
 / / / _ `/ _ \/ -_|_-</ __/ __/ // / /__ \  
/_/  \_,_/ .__/\__/___/\__/_/  \_, / /____/ 
        /_/                   /___/  5.4.1 (development mode)   
[INFO] Started [email protected]:8080 
[INFO] Started Jetty Server

अब तक, हमने टेपेस्ट्री में एक बेसिक क्विक स्टार्ट प्रोजेक्ट बनाया है। वेब ब्राउज़र में चल रहे एप्लिकेशन को देखने के लिए, पता बार में निम्न URL टाइप करें और एंटर दबाएं -

https://localhost:8080/myapp

यहाँ, myapp एप्लिकेशन का नाम है और डेवलपमेंट मोड में एप्लिकेशन का डिफ़ॉल्ट पोर्ट 8080 है।

ग्रहण का उपयोग करना

पिछले अध्याय में, हमने CLI में एक टेपेस्ट्री क्विक स्टार्ट एप्लिकेशन बनाने के बारे में चर्चा की। यह अध्याय एक कंकाल के अनुप्रयोग को बनाने के बारे में बताता हैEclipse IDE

आइए हम कंकाल के अनुप्रयोग को बनाने के लिए एक मावेन आर्कटाइप का उपयोग करें। नए एप्लिकेशन को कॉन्फ़िगर करने के लिए, आप नीचे दिए गए चरणों का पालन कर सकते हैं।

चरण 1: ग्रहण आईडीई खोलें

अपना ग्रहण खोलें और फ़ाइल चुनें → नया → प्रोजेक्ट… → विकल्प जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

अब, Maven → Maven प्रोजेक्ट विकल्प चुनें।

Note - यदि मावेन कॉन्फ़िगर नहीं है, तो कॉन्फ़िगर करें और एक प्रोजेक्ट बनाएं।

मावेन प्रोजेक्ट को चुनने के बाद, नेक्स्ट पर क्लिक करें और फिर नेक्स्ट बटन पर क्लिक करें।

उसके बाद, आपको एक स्क्रीन मिलेगी जहां आपको कॉन्फ़िगर विकल्प चुनना चाहिए। एक बार यह कॉन्फ़िगर हो जाने के बाद, आपको निम्न स्क्रीन मिलेगी।

चरण 2: कैटलॉग कॉन्फ़िगरेशन

पहला चरण पूरा होने के बाद, आपको क्लिक करना चाहिए Add Remote Catalog। फिर निम्न स्क्रीनशॉट में दिखाए अनुसार निम्न बदलाव जोड़ें।

अब, अपाचे टेपेस्ट्री कैटलॉग जोड़ा गया है। फिर, नीचे दिखाए अनुसार फ़िल्टर विकल्प org.apache.tapestry quickstart 5.4.1 चुनें।

फिर नेक्स्ट पर क्लिक करें और निम्न स्क्रीन दिखाई देगी।

चरण 3: कॉन्फ़िगर GroupId, ArtifactId, संस्करण और पैकेज

टेपेस्ट्री कैटलॉग कॉन्फ़िगरेशन में निम्न परिवर्तन जोड़ें।

फिर फिनिश बटन पर क्लिक करें, अब हमने पहला कंकाल एप्लिकेशन बनाया है। पहली बार जब आप मावेन का उपयोग करते हैं, तो प्रोजेक्ट निर्माण में थोड़ा समय लग सकता है क्योंकि मावेन मावेन, जेट्टी और टेपेस्ट्री के लिए कई जार निर्भरता डाउनलोड करता है। मावेन खत्म होने के बाद, आप अपने पैकेज एक्सप्लोरर दृश्य में एक नई निर्देशिका, MyFirstApplication देखेंगे।

चरण 4: जेट्टी सर्वर का उपयोग करके एप्लिकेशन को चलाएं

जेट्टी को सीधे चलाने के लिए आप मावेन का उपयोग कर सकते हैं। अपने पैकेज एक्सप्लोरर दृश्य में MyFirstApplication परियोजना पर राइट-क्लिक करें और रन अस → मावेन बिल्ड का चयन करें ... आपको नीचे दी गई स्क्रीन दिखाई देगी।

कॉन्फ़िगरेशन डायलॉग बॉक्स में, "जेट्टी: रन" के रूप में लक्ष्य विकल्प दर्ज करें फिर रन बटन पर क्लिक करें।

जेट्टी आरंभ होने के बाद, आप अपने कंसोल में निम्न स्क्रीन देखेंगे।

चरण 5: वेब ब्राउज़र में चलाएं

वेब ब्राउज़र में एप्लिकेशन चलाने के लिए निम्न URL टाइप करें -

https://loclhost:8080/MyFirstApplication

चरण 6: जेट्टी सर्वर बंद करो

जेट्टी सर्वर को रोकने के लिए, अपने कंसोल में लाल वर्ग आइकन पर क्लिक करें जैसा कि नीचे दिखाया गया है।

यहाँ स्रोत कोड का लेआउट बनाया गया है Maven Quickstart CLI। इसके अलावा, यह एक मानक टेपेस्ट्री एप्लिकेशन का सुझावित लेआउट है।

├── build.gradle 
├── gradle 
│   └── wrapper 
│       ├── gradle-wrapper.jar 
│       └── gradle-wrapper.properties 
├── gradlew 
├── gradlew.bat 
├── pom.xml 
├── src 
│   ├── main 
│   │   ├── java 
│   │   │   └── com 
│   │   │       └── example 
│   │   │           └── MyFirstApplication 
│   │   │               ├── components 
│   │   │               ├── data 
│   │   │               ├── entities 
│   │   │               ├── pages 
│   │   │               └── services 
│   │   ├── resources 
│   │   │   ├── com 
│   │   │   │   └── example 
│   │   │   │       └── MyFirstApplication 
│   │   │   │           ├── components 
│   │   │   │           ├── logback.xml 
│   │   │   │           └── pages 
│   │   │   │               └── Index.properties  
│   │   │   ├── hibernate.cfg.xml 
│   │   │   └── log4j.properties
│   │   └── webapp 
│   │       ├── favicon.ico 
│   │       ├── images 
│   │       │   └── tapestry.png 
│   │       ├── mybootstrap 
│   │       │   ├── css 
│   │       │   │   ├── bootstrap.css 
│   │       │   │   └── bootstrap-theme.css 
│   │       │   ├── fonts 
│                   ├── glyphicons-halflings-regular.eot 
│   │       │   │   ├── glyphicons-halflings-regular.svg 
│   │       │   │   ├── glyphicons-halflings-regular.ttf 
│   │       │   │   ├── glyphicons-halflings-regular.woff 
│   │       │   │   └── glyphicons-halflings-regular.woff2 
│   │       │   └── js 
│   │       └── WEB-INF 
│   │           ├── app.properties 
│   │           └── web.xml 
│   ├── site 
│   │   ├── apt 
│   │   │   └── index.apt 
│   │   └── site.xml 
│   └── test 
│       ├── conf 
│       │   ├── testng.xml 
│       │   └── webdefault.xml 
│       ├── java 
│       │   └── PLACEHOLDER 
│       └── resources 
│           └── PLACEHOLDER 
└── target     
   ├── classes     
   │   ├── com  
   │   │   └── example
   │   │       └── MyFirstApplication     
   │   │           ├── components     
   │   │           ├── data     
   │   │           ├── entities     
   │   │           ├── logback.xml     
   │   │           ├── pages 
   │   │           │   └── Index.properties 
   │   │           └── services     
   │   ├── hibernate.cfg.xml 
   │   └── log4j.properties     
   ├── m2e-wtp 
   │   └── web-resources 
   │       └── META-INF     
   │           ├── MANIFEST.MF 
   │           └── maven 
   │               └── com.example 
   │                   └──MyFirstApplication     
   │                     ├── pom.properties 
   │                       └── pom.xml     
   ├── test-classes 
   │   └── PLACEHOLDER 
   └── work         
      ├── jsp         
      ├── sampleapp.properties 
      └── sampleapp.script

डिफ़ॉल्ट लेआउट की तरह व्यवस्था की है WAR Internal File Format। WAR प्रारूप का उपयोग पैकेजिंग और तैनाती के बिना एप्लिकेशन को चलाने में मदद करता है। यह लेआउट केवल एक सुझाव है, लेकिन आवेदन किसी भी प्रारूप में व्यवस्थित किया जा सकता है, अगर इसे तैनात करते समय उचित WAR प्रारूप में पैक किया गया हो।

स्रोत कोड को निम्नलिखित चार मुख्य वर्गों में विभाजित किया जा सकता है।

  • Java Code - सभी जावा स्रोत कोड के तहत रखा गया है /src/main/javaफ़ोल्डर। टेपेस्ट्री पेज कक्षाएं "पेज" फ़ोल्डर के तहत रखी जाती हैं और टेपेस्ट्री घटक कक्षाएं घटक फ़ोल्डर के तहत रखी जाती हैं। टेपेस्ट्री सेवा वर्गों को सेवा फ़ोल्डर के अंतर्गत रखा जाता है।

  • ClassPath Resources- टेपेस्ट्री में, अधिकांश कक्षाओं में संबद्ध संसाधन (XML टेम्पलेट, जावास्क्रिप्ट फ़ाइलें, आदि) हैं। इन संसाधनों के तहत रखा गया है/src/main/resourcesफ़ोल्डर। टेपेस्ट्री पेज क्लासेस के "पेज" फोल्डर के तहत इसके संबंधित संसाधन होते हैं और टेपेस्ट्री घटक कक्षाओं के पास घटक फ़ोल्डर के तहत इसके संबंधित संसाधन होते हैं। इन संसाधनों में पैक किया जाता हैWEB-INF/classes WAR का फ़ोल्डर।

  • Context Resources - वे इमेज, स्टाइल शीट और जावास्क्रिप्ट लाइब्रेरी जैसे वेब एप्लिकेशन के स्थिर संसाधन हैं / Modules. They are usually placed under the /src/main/webapp फ़ोल्डर और वे कहते हैं Context Resources। इसके अलावा, वेब एप्लिकेशन विवरण फ़ाइल (जावा सर्वलेट की), web.xml के नीचे रखी गई हैWEB-INF संदर्भ संसाधनों का फ़ोल्डर।

  • Testing Code - ये वैकल्पिक फाइलें हैं जिनका उपयोग एप्लिकेशन का परीक्षण करने के लिए किया जाता है src/test/java तथा src/test/संसाधन फ़ोल्डर। उन्हें WAR में पैक नहीं किया जाता है।

अपाचे टेपेस्ट्री इस प्रकार है Convention over Configurationप्रोग्रामिंग के हर पहलू में। फ्रेमवर्क की प्रत्येक विशेषता में एक समझदार डिफ़ॉल्ट सम्मेलन है।

उदाहरण के लिए, जैसा कि हमने प्रोजेक्ट लेआउट चैप्टर में सीखा है, सभी पेजों को इसमें रखा जाना चाहिए /src/main/java/«package_path»/pages/ फ़ोल्डर जिसे टेपेस्ट्री पेज माना जाता है।

एक अन्य अर्थ में, किसी विशेष जावा क्लास को टेपेस्ट्री पेज के रूप में कॉन्फ़िगर करने की आवश्यकता नहीं है। कक्षा को पूर्व-निर्धारित स्थान पर रखना पर्याप्त है। कुछ मामलों में, टेपेस्ट्री के डिफ़ॉल्ट सम्मेलन का पालन करना अजीब है।

उदाहरण के लिए, टेपेस्ट्री घटक में एक विधि हो सकती है setupRenderजो प्रतिपादन चरण शुरू में निकाल दिया जाएगा। एक डेवलपर अपने स्वयं के प्रमाणित नाम का उपयोग करना चाह सकता है, कहते हैंinitializeValue। इस स्थिति में, टेपेस्ट्री प्रदान करता हैAnnotation निम्नलिखित कोड ब्लॉक में दिखाए गए सम्मेलनों को ओवरराइड करने के लिए।

void setupRender() { 
   // initialize component 
}  
@SetupRender 
void initializeValue() { 
   // initialize component 
}

टेपेस्ट्री में प्रोग्रामिंग के दोनों तरीके मान्य हैं। संक्षेप में, टेपेस्ट्री का डिफ़ॉल्ट विन्यास काफी न्यूनतम है। सिर्फApache Tapestry Filter (Java Servlet Filter) एप्लिकेशन के उचित कार्य के लिए "Web.xml" में कॉन्फ़िगर करने की आवश्यकता है।

टेपेस्ट्री अनुप्रयोग को कॉन्फ़िगर करने के लिए एक और तरीका प्रदान करता है और इसे कहा जाता है AppModule.java

टेपेस्ट्री द्वारा वेब एप्लिकेशन डेवलपमेंट को सरल बनाने के लिए एनोटेशन एक बहुत महत्वपूर्ण विशेषता है। टेपेस्ट्री बहुत सारे कस्टम एनोटेशन प्रदान करता है। इसमें वर्गों, विधियों और सदस्य फ़ील्ड्स के लिए एनोटेशन है। जैसा कि पिछले अनुभाग में चर्चा की गई है, एनोटेशन का उपयोग किसी सुविधा के डिफ़ॉल्ट सम्मेलन को ओवरराइड करने के लिए भी किया जा सकता है। टेपेस्ट्री एनोटेशन को चार मुख्य श्रेणियों में बांटा गया है और वे इस प्रकार हैं।

घटक एनोटेशन

पेज, कंपोनेंट और मिक्सिंस क्लासेस में उपयोग किया जाता है। कुछ उपयोगी टिप्पणियां हैं -

  • @Property- यह खेतों पर लागू है। एक फ़ील्ड को टेपेस्ट्री प्रॉपर्टी में बदलने के लिए उपयोग किया जाता है।

  • @Parameter- यह खेतों पर लागू है। एक घटक के पैरामीटर के रूप में एक क्षेत्र निर्दिष्ट करने के लिए उपयोग किया जाता है।

  • @Environmental- यह खेतों पर लागू है। विभिन्न घटकों के बीच एक निजी क्षेत्र को साझा करने के लिए उपयोग किया जाता है।

  • @import- यह कक्षाओं और क्षेत्रों के लिए लागू है। एसेट्स, सीएसएस और जावास्क्रिप्ट को शामिल करने के लिए उपयोग किया जाता है।

  • @Path - एक मार्ग पर आधारित एसेट को इंजेक्ट करने के लिए @ इंजेक्शन एनोटेशन के साथ संयोजन में उपयोग किया जाता है।

  • @Log- यह कक्षाओं और क्षेत्रों के लिए लागू है। डिबगिंग उद्देश्यों के लिए उपयोग किया जाता है। उपयोग किया जा सकता है घटक की घटना की जानकारी जैसे कि कार्यक्रम की शुरुआत, घटना का अंत, आदि।

IoC एनोटेशन

IoC कंटेनर में वस्तुओं को इंजेक्ट करने के लिए उपयोग किया जाता है। कुछ उपयोगी टिप्पणियां हैं -

  • @Inject- यह खेतों पर लागू है। उन मापदंडों को चिह्नित करने के लिए उपयोग किया जाता है जिन्हें आईओसी कंटेनर में इंजेक्ट किया जाना चाहिए। यह उन क्षेत्रों को चिह्नित करता है जिन्हें घटकों में इंजेक्ट किया जाना चाहिए।

  • @Value- यह खेतों पर लागू है। एक सेवा के बजाय शाब्दिक मूल्य को इंजेक्ट करने के लिए @inject एनोटेशन के साथ उपयोग किया जाता है (जो @Inject एनोटेशन का डिफ़ॉल्ट व्यवहार है)।

डेटा होल्डिंग कक्षाओं के लिए एनोटेशन

इसका उपयोग उच्च स्तर के घटकों जैसे (आमतौर पर मॉडल या डेटा होल्डिंग क्लासेस) के वर्ग विशेष में घटक विशेष जानकारी को निर्दिष्ट करने के लिए किया जाता है

  • Grid (रिपोर्ट, गैलरी, आदि जैसे उन्नत सारणीबद्ध डेटा बनाने के लिए उपयोग किया जाता है)

  • BeanEditForm (उन्नत रूप बनाने के लिए प्रयुक्त)

  • Hibernate (उन्नत डेटाबेस एक्सेस में प्रयुक्त), आदि।

इन एनोटेशनों को बिना किसी टेपेस्ट्री निर्भरता के एक अलग जार में एकत्रित और पैक किया जाता है। कुछ एनोटेशन हैं -

  • @DataType- इसका उपयोग फ़ील्ड के डेटा प्रकार को निर्दिष्ट करने के लिए किया जाता है। टेपेस्ट्री घटक इस जानकारी का उपयोग प्रस्तुति परत में डिज़ाइन या मार्कअप बनाने के लिए कर सकता है।

  • @Validate - इसका उपयोग किसी क्षेत्र के लिए सत्यापन नियम को निर्दिष्ट करने के लिए किया जाता है।

ये पृथक्करण टेपेस्ट्री अनुप्रयोग का उपयोग करने में सक्षम करते हैं Multi-Tier Design

टेपेस्ट्री एप्लिकेशन बस टेपेस्ट्री पेजों का एक संग्रह है। वे एक अच्छी तरह से परिभाषित वेब अनुप्रयोग बनाने के लिए एक साथ काम करते हैं। प्रत्येक पृष्ठ में एक ही XML टेम्प्लेट और शून्य, एक या अधिक घटक होंगे। पृष्ठ और घटक समान हैं सिवाय इसके कि पृष्ठ एक मूल घटक है और आमतौर पर एक एप्लिकेशन डेवलपर द्वारा बनाया जाता है।

Components are children of the root Pagecomponent। टेपेस्ट्री में बहुत सारे अंतर्निर्मित घटक होते हैं और एक कस्टम घटक बनाने का विकल्प होता है।

पृष्ठों

जैसा कि पहले चर्चा की गई थी, पेज एक टेपेस्ट्री एप्लिकेशन के ब्लॉक का निर्माण कर रहे हैं। पृष्ठ सादे POJO हैं, जिनके नीचे -/src/main/java/«package_path»/pages/फ़ोल्डर। प्रत्येक पृष्ठ पर एक अनुरूप होगाXML Template और इसका डिफ़ॉल्ट स्थान है - /src/main/resources/«package_name»/pages/

आप यहां देख सकते हैं कि पथ संरचना पृष्ठ और टेम्पलेट के लिए समान है सिवाय इसके कि टेम्पलेट अंदर है Resource Folder

उदाहरण के लिए, पैकेज नाम के साथ टेपेस्ट्री एप्लिकेशन में एक उपयोगकर्ता पंजीकरण पृष्ठ - com.example.MyFirstApplication निम्न पृष्ठ और टेम्पलेट फ़ाइलें होंगी -

  • Java Class -

    /src/main/java/com/example/MyFirstApplication/pages/index.java

  • XML Template -

    /src/main/resources/com/example/MyFirstApplication/pages/index.tml

आइए हम एक सरल बनाएं Hello Worldपृष्ठ। सबसे पहले, हमें एक बनाने की जरूरत हैJava Class at - /src/main/java/com/example/MyFirstApplication/pages/HelloWorld.java ”।

package com.example.MyFirstApplication.pages; 
public class HelloWorld { 
}

फिर, पर एक XML टेम्पलेट बनाएँ -

"/Src/main/resources/com/example/MyFirstApplication/pages/helloworld.html"।

<html xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"> 
   <head> 
      <title>Hello World Page</title> 
   </head> 
   <body> 
      <h1>Hello World</h1> 
   </body> 
</html>

अब, इस पृष्ठ पर पहुँचा जा सकता है https://localhost:8080/myapp/helloworld। यह एक साधारण टेपेस्ट्री पेज है। टेपेस्ट्री गतिशील वेब पेज विकसित करने के लिए बहुत अधिक सुविधाएँ प्रदान करती है, जिसकी चर्चा हम निम्नलिखित अध्यायों में करेंगे।

आइए इस खंड में टेपेस्ट्री XML टेम्प्लेट पर विचार करें। XML टेम्प्लेट एक सुव्यवस्थित XML डॉक्यूमेंट है। किसी पृष्ठ की प्रस्तुति (यूजर इंटरफेस) परत XML टेम्प्लेट है। XML टेम्प्लेट में नीचे दी गई वस्तुओं के अतिरिक्त सामान्य HTML मार्कअप है -

  • टेपेस्ट्री नेमस्पेस
  • Expansions
  • Elements
  • Components

आइए अब हम उनके बारे में विस्तार से चर्चा करते हैं।

टेपेस्ट्री नेमस्पेस

टेपेस्ट्री नेमस्पेस, एक्सएमएल नेमस्पेस के अलावा कुछ भी नहीं हैं। टेम्पलेट के मूल तत्व में नाम स्थान को परिभाषित किया जाना चाहिए। इसका उपयोग टेपेस्ट्री घटकों और घटक संबंधी जानकारी को टेम्प्लेट में शामिल करने के लिए किया जाता है। सबसे अधिक उपयोग किए जाने वाले नामस्थान इस प्रकार हैं -

  • xmlns: t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" - इसका उपयोग टेपेस्ट्री के तत्वों, अवयवों और गुणों की पहचान करने के लिए किया जाता है।

  • xmlns: p = "टेपेस्ट्री: पैरामीटर" - इसका उपयोग कोड के मनमाने ढंग से घटकों को पास करने के लिए किया जाता है।

टेपेस्ट्री नेमस्पेस का एक उदाहरण इस प्रकार है -

<html xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_3.xsd" 
   xmlns:p = "tapestry:parameter"> 
   
   <head> 
      <title>Hello World Page</title> 
   </head>  
   <body> 
      <h1>Hello World</h1> 
      <t:eventlink page = "Index">refresh page</t:eventlink> 
   </body> 
</html>

विस्तार

विस्तार पृष्ठ के रेंडरिंग चरण के दौरान XML टेम्प्लेट को गतिशील रूप से बदलने के लिए सरल और कुशल तरीका है। विस्तार $ {<name>} सिंटैक्स का उपयोग करता है। एक्सएमएल टेम्पलेट में विस्तार को व्यक्त करने के लिए कई विकल्प हैं। आइए देखते हैं सबसे अधिक इस्तेमाल किए जाने वाले कुछ विकल्प -

संपत्ति का विस्तार

यह संबंधित पेज क्लास में परिभाषित संपत्ति को मैप करता है। यह जावा वर्ग में संपत्ति की परिभाषा के लिए जावा बीन विनिर्देशन का अनुसरण करता है। यह संपत्ति के नाम के मामलों की अनदेखी करके एक कदम और आगे बढ़ जाता है। हमें संपत्ति विस्तार का उपयोग करके "हैलो वर्ल्ड" उदाहरण बदलते हैं। निम्न कोड ब्लॉक संशोधित पृष्ठ वर्ग है।

package com.example.MyFirstApplication.pages; 
public class HelloWorld {   
   // Java Bean Property 
   public String getName { 
      return "World!"; 
   } 
}

फिर, नीचे दिखाए गए अनुसार संबंधित XML टेम्प्लेट को बदलें।

<html xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"> 
   <head> 
      <title>Hello World Page</title> 
   </head> 
   <body> 
      <!-- expansion --> 
      <h1>Hello ${name}</h1> 
   </body> 
</html>

यहाँ, हमने परिभाषित किया है name जैसा Java Bean Property पेज क्लास में और विस्तार से एक्सएमएल टेम्पलेट में डायनामिक तरीके से इसे प्रोसेस किया ${name}

संदेश विस्तार

प्रत्येक पृष्ठ वर्ग में संबंधित संपत्ति फ़ाइल हो सकती है या नहीं भी हो सकती है - «page_name».propertiesसंसाधन फ़ोल्डर में। संपत्ति फाइलें सादे पाठ फाइलें हैं जो प्रति पंक्ति एकल कुंजी / मान युग्म (संदेश) हैं। हमें HelloWorld पेज के लिए एक संपत्ति फ़ाइल बनाएँ -

"Asrc/main/resources/com/example/MyFirstApplication/pages/helloworld.properties" और "ग्रीटिंग" संदेश जोड़ें।

Greeting = Hello

Greeting संदेश का उपयोग XML टेम्प्लेट में किया जा सकता है ${message:greeting}

<html xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"> 
   <head> 
      <title>Hello World Page</title> 
   </head> 
   <body> 
      <!-- expansion --> 
      <h1>${message:greeting} ${name}</h1> 
   </body> 
</html>

तत्वों

टेपेस्ट्री में एक्सएमएल टेम्प्लेट्स में उपयोग किए जाने वाले तत्वों का एक छोटा सा सेट है। तत्व पूर्वनिर्धारित टैग टेपेस्ट्री नामस्थान के तहत परिभाषित हैं -

https://tapestry.apache.org/schema/tapestry_5_4.xsd

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

<टी: शरीर>

जब दो घटकों को नेस्ट किया जाता है, तो माता-पिता घटक के टेम्पलेट को बाल घटक के टेम्पलेट को लपेटना पड़ सकता है। इस स्थिति में <t: body> तत्व उपयोगी है। टेम्पलेट लेआउट में <t: body> के उपयोगों में से एक है।

सामान्य तौर पर, एक वेब एप्लिकेशन के यूजर इंटरफेस में एक कॉमन हैडर, फुटर, मेनू इत्यादि होंगे। इन सामान्य वस्तुओं को एक्सएमएल टेम्पलेट में परिभाषित किया गया है और इसे टेम्प्लेट लेआउट या लेआउट कंपोनेंट कहा जाता है। टेपेस्ट्री में, इसे एक एप्लिकेशन डेवलपर द्वारा बनाया जाना चाहिए। एक लेआउट कंपोनेंट सिर्फ एक अन्य घटक है और इसे घटक फ़ोल्डर के नीचे रखा जाता है, जिसमें निम्न पथ हैं -src/main/«java|resources»/«package_name»/components

आइए हम एक सरल लेआउट घटक बनाते हैं जिसे कहा जाता है MyCustomLayout। MyCustomLayout का कोड इस प्रकार है -

<!DOCTYPE html> 
<html xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"> 
   <head> 
      <meta charset = "UTF-8" />
      <title>${title}</title>  
   </head> 
   <body> 
      <div>Sample Web Application</div> 
      <h1>${title}</h1> 
      <t:body/> 
      
      <div>(C) 2016 TutorialsPoint.</div> 
   </body> 
</html>

package com.example.MyFirstApplication.components;  

import org.apache.tapestry5.*; 
import org.apache.tapestry5.annotations.*; 
import org.apache.tapestry5.BindingConstants;  

public class MyCustomLayout { 
   @Property 
   @Parameter(required = true, defaultPrefix = BindingConstants.LITERAL) 
      private String title; 
}

MyCustomLayout घटक वर्ग में, हमने एक शीर्षक फ़ील्ड घोषित किया और एनोटेशन का उपयोग करके, हमने इसे अनिवार्य बना दिया है। अब, नीचे दिए गए कोड ब्लॉक में दिखाए गए अनुसार हमारे कस्टम लेआउट का उपयोग करने के लिए HelloWorld.html टेम्पलेट बदलें।

<html>
   t:type = "mycustomlayout" title = "Hello World Test page"
      xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"> 
   <h1>${message:greeting} ${name}</h1> 
</html>

हम यहां देख सकते हैं कि XML टेम्प्लेट में हेड और बॉडी टैग नहीं हैं। टेपेस्ट्री लेआउट घटक से इन विवरणों को इकट्ठा करेगा और लेआउट घटक के <t: body> को HelloWorld टेम्पलेट द्वारा प्रतिस्थापित किया जाएगा। एक बार सब कुछ हो जाने के बाद, टेपेस्ट्री नीचे दिए गए अनुसार समान मार्कअप का उत्सर्जन करेगी -

<!DOCTYPE html> 
<html> 
   <head> 
      <meta charset = "UTF-8" /> 
      <title>Hello World Test Page</title> 
   </head> 
   <body> 
      <div>Sample Web Application</div> 
      <h1>Hello World Test Page</h1> 
      <h1>Hello World!</h1> 
      <div>(C) 2016 TutorialsPoint.</div> 
   </body> 
</html>

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

<html t:type = "MyCommonLayout" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"> 
   
   <div><!-- Admin related items --><div> 
   <t:body/> 
  
</html>

<टी: कंटेनर>

<T: कंटेनर> एक शीर्ष-स्तरीय तत्व है और इसमें टेपेस्ट्री नाम स्थान शामिल है। यह एक घटक के गतिशील अनुभाग को निर्दिष्ट करने के लिए उपयोग किया जाता है।

उदाहरण के लिए, एक ग्रिड घटक को HTML तालिका के भीतर अपनी पंक्तियों - tr (और स्तंभ td) को प्रस्तुत करने के तरीके की पहचान करने के लिए टेम्पलेट की आवश्यकता हो सकती है।

<t:container xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"> 
   <td>${name}</td> 
   <td>${age}</td> 
</t:container>

<टी: ब्लॉक>

<T: ब्लॉक> टेम्पलेट में एक गतिशील अनुभाग के लिए एक प्लेसहोल्डर है। आम तौर पर, ब्लॉक तत्व रेंडर नहीं करता है। केवल, टेम्पलेट में परिभाषित घटक ब्लॉक तत्व का उपयोग करते हैं। घटक डेटा को गतिशील रूप से ब्लॉक तत्व में इंजेक्ट करेंगे और इसे रेंडर करेंगे। लोकप्रिय उपयोग मामले में से एक हैAJAX

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

@Inject 
private Block block;  
<html t:type = "mycustomlayout" title = "block example" 
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
<h1>${title}</h1>  
<!--  
   ... 
   ...  
--> 
<t:block t:id = "block"> 
   <h2>Highly dynamic section</h2> 
   I'v been updated through AJAX call 
   The current time is: <strong>${currentTime}</strong>
</t:block>  
<!--  
   ... 
   ...  
-->  
</html>

<टी: सामग्री>

टेम्पलेट की वास्तविक सामग्री को निर्दिष्ट करने के लिए <t: सामग्री> तत्व का उपयोग किया जाता है। सामान्य तौर पर, सभी मार्कअप टेम्पलेट का हिस्सा माना जाता है। यदि <t: सामग्री> निर्दिष्ट है, तो इसके अंदर केवल मार्कअप माना जाएगा। यह सुविधा डिजाइनरों द्वारा लेआउट घटक के बिना एक पृष्ठ डिजाइन करने के लिए उपयोग की जाती है।

<टी: निकालें>

<T: remove> सामग्री तत्व के ठीक विपरीत है। हटाए गए तत्व के अंदर मार्कअप को टेम्पलेट का हिस्सा नहीं माना जाता है। इसका उपयोग सर्वर के लिए केवल टिप्पणियों और डिजाइनिंग उद्देश्यों के लिए किया जा सकता है।

संपत्ति

एसेट्स स्टैटिक रिसोर्स फाइल्स जैसे स्टाइल शीट, इमेज और जावास्क्रिप्ट फाइल्स हैं। आम तौर पर, संपत्ति को वेब एप्लिकेशन रूट डायरेक्टरी में रखा जाता है/src/main/webapp

<head> 
   <link href = "/css/site.css" rel = "stylesheet" type = "text/css"/>

टेपेस्ट्री में संग्रहीत फ़ाइलों का भी इलाज करता है Java Classpathआस्तियों के रूप में। टेपेस्ट्री विस्तार विकल्प के माध्यम से परिसंपत्तियों को टेम्पलेट में शामिल करने के लिए उन्नत विकल्प प्रदान करता है।

  • Context - वेब संदर्भ में संपत्ति उपलब्ध कराने का विकल्प।

<img src = "${context:image/tapestry_banner.gif}" alt = "Banner"/>

asset- घटक आमतौर पर जावा कक्षाओं के साथ-साथ जार फ़ाइल के अंदर अपनी संपत्ति को संग्रहीत करते हैं। टेपेस्ट्री 5.4 से शुरू, क्लासपाथ में संपत्ति को स्टोर करने का मानक पथ हैMETA-INF/assets। पुस्तकालयों के लिए, संपत्ति को संग्रहीत करने का मानक पथ हैMETA-INF/assets/«library_name»/. asset: भी कॉल कर सकते हैं context: वेब संदर्भ से संपत्ति प्राप्त करने के लिए विस्तार।

<img src = "${asset:context:image/tapestry_banner.gif}" alt = "Banner"/>

संपत्ति को टेपेस्ट्री पेज या घटक में इंजेक्ट और पथ एनोटेशन का उपयोग करके इंजेक्ट किया जा सकता है। पथ एनोटेशन के लिए पैरामीटर संपत्ति का सापेक्ष पथ है।

@Inject 
@Path("images/edit.png") 
private Asset icon;

Path parameter इसमें टेपेस्ट्री प्रतीक भी शामिल हो सकते हैं AppModule.java अनुभाग।

उदाहरण के लिए, हम एक प्रतीक, त्वचा को परिभाषित कर सकते हैं। मूल्य संदर्भ के साथ त्वचा: खाल / मूल और इसे नीचे दिखाए अनुसार उपयोग करें -

@Inject 
@Path("${skin.root}/style.css") 
private Asset style;

स्थानीयकरण

टेपेस्ट्री के माध्यम से संसाधनों को शामिल करना अतिरिक्त कार्यक्षमता प्रदान करता है। ऐसी ही एक कार्यक्षमता "स्थानीयकरण" है। टेपेस्ट्री वर्तमान स्थान की जांच करेगी और उचित संसाधनों को शामिल करेगी।

उदाहरण के लिए, यदि वर्तमान लोकेल को सेट किया गया है de, फिर edit_de.png edit.png के बजाय शामिल किया जाएगा।

सीएसएस

टेपेस्ट्री में बिल्ट-इन स्टाइल शीट सपोर्ट है। टेपेस्ट्री इंजेक्ट करेंगेtapestry.cssकोर जावास्क्रिप्ट स्टैक के एक भाग के रूप में। टेपेस्ट्री 5.4 से, टेपेस्ट्री शामिल हैंbootstrap css frameworkभी। हम सामान्य लिंक टैग का उपयोग करके अपनी खुद की स्टाइल शीट शामिल कर सकते हैं। इस मामले में, स्टाइल शीट वेब रूट डायरेक्टरी में होनी चाहिए -/src/main/webapp/

<head> 
   <link href = "/css/site.css" rel = "stylesheet" type = "text/css"/>

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

<head> 
   <link href = "${context:css/site.css}" rel = "stylesheet" type = "text/css"/>

टेपेस्ट्री जावा कक्षाओं में सीधे स्टाइल शीट को शामिल करने के लिए आयात एनोटेशन भी प्रदान करता है।

@Import(stylesheet="context:css/site.css") 
public class MyCommonLayout { 
}

टेपेस्ट्री AppModule.java के माध्यम से स्टाइल शीट का प्रबंधन करने के लिए बहुत सारे विकल्प प्रदान करता है। कुछ महत्वपूर्ण विकल्प हैं -

  • टेपेस्ट्री डिफ़ॉल्ट स्टाइल शीट को हटाया जा सकता है।

@Contribute(MarkupRenderer.class) 

public static void 
deactiveDefaultCSS(OrderedConfiguration<MarkupRendererFilter> configuration) { 
   configuration.override("InjectDefaultStyleheet", null); 
}
  • बूटस्ट्रैप को इसके पथ को ओवरराइड करके भी अक्षम किया जा सकता है।

configuration.add(SymbolConstants.BOOTSTRAP_ROOT, "classpath:/METAINF/assets");
  • संपत्ति (सीएसएस और जावास्क्रिप्ट) के गतिशील न्यूनतम सक्षम करें। हमें शामिल करने की आवश्यकता हैtapestry-webresources निर्भरता (pom.xml में) भी।

@Contribute(SymbolProvider.class) 
@ApplicationDefaults 

public static void contributeApplicationDefaults( 
   MappedConfiguration<String, String> configuration) { 
   
   configuration.add(SymbolConstants.MINIFICATION_ENABLED, "true"); 
} 

<dependency> 
   <groupId>org.apache.tapestry</groupId> 
   <artifactId>tapestry-webresources</artifactId> 
   <version>5.4</version> 
</dependency>

क्लाइंट साइड जावास्क्रिप्ट

समृद्ध ग्राहक पक्ष अनुभव प्रदान करने के लिए वेब एप्लिकेशन की वर्तमान पीढ़ी भारी रूप से जावास्क्रिप्ट पर निर्भर करती है। टेपेस्ट्री इसे स्वीकार करती है और जावास्क्रिप्ट के लिए प्रथम श्रेणी का समर्थन प्रदान करती है। जावास्क्रिप्ट समर्थन टेपेस्ट्री में गहराई से जुड़ा हुआ है और प्रोग्रामिंग के हर चरण में उपलब्ध है।

इससे पहले, टेपेस्ट्री केवल प्रोटोटाइप और स्क्रिप्टैकुलस का समर्थन करते थे। लेकिन, संस्करण 5.4 से, टेपेस्ट्री ने जावास्क्रिप्ट परत को पूरी तरह से फिर से लिखा है ताकि इसे यथासंभव सामान्य बनाया जा सके और जावास्क्रिप्ट के लिए डी-फैक्टो लाइब्रेरी JQuery के लिए प्रथम श्रेणी का समर्थन प्रदान किया जा सके। इसके अलावा, टेपेस्ट्री मॉड्यूल आधारित जावास्क्रिप्ट प्रोग्रामिंग को प्रोत्साहित करती है और एएमडी (असिंक्रोनस मॉड्यूल परिभाषा - जावास्क्रिप्ट विनिर्देश मॉड्यूल का समर्थन करने के लिए और एक अतुल्यकालिक तरीके से निर्भरता) के एक लोकप्रिय क्लाइंट साइड कार्यान्वयन की आवश्यकता है।

स्थान

जावास्क्रिप्ट फाइलें टेपेस्ट्री एप्लिकेशन की संपत्ति हैं। संपत्ति नियमों के अनुसार, जावास्क्रिप्ट फ़ाइलों को वेब संदर्भ के तहत रखा जाता है,/sr/main/webapp/ या जार के अंदर रखा META-INF/assets/ location

जावास्क्रिप्ट फ़ाइलें जोड़ना

XML टेम्प्लेट में जावास्क्रिप्ट फ़ाइलों को लिंक करने का सबसे सरल तरीका सीधे स्क्रिप्ट टैग का उपयोग करके है, जो है - <script language = "javascript" src = "relative/path/to/js"></script>। लेकिन, टेपेस्ट्री इन दृष्टिकोणों की सिफारिश नहीं करता है। टेपेस्ट्री पेज / कंपोनेंट में ही जावास्क्रिप्ट फ़ाइलों को लिंक करने के लिए कई विकल्प प्रदान करता है। इनमें से कुछ नीचे दिए गए हैं।

  • @import annotation- @import एनोटेशन संदर्भ अभिव्यक्ति का उपयोग करके कई जावास्क्रिप्ट लाइब्रेरी को लिंक करने का विकल्प प्रदान करता है। इसे पेज क्लास और इसकी विधि दोनों पर लागू किया जा सकता है। यदि किसी पृष्ठ वर्ग पर लागू किया जाता है, तो यह उसके सभी तरीकों पर लागू होता है। यदि पृष्ठ के तरीके पर लागू किया जाता है, तो यह केवल उस पद्धति पर लागू होता है और फिर टेपेस्ट्री जावास्क्रिप्ट लाइब्रेरी को लिंक करता है, जब यह विधि लागू होती है।

@Import(library = {"context:js/jquery.js","context:js/myeffects.js"}) 

public class MyComponent { 
   // ... 
}
  • JavaScriptSupport interface - JavaScriptSupport टेपेस्ट्री द्वारा परिभाषित एक इंटरफ़ेस है और इसकी एक विधि है, importJavaScriptLibraryजावास्क्रिप्ट फ़ाइलों को आयात करने के लिए। JavScriptSupport ऑब्जेक्ट को आसानी से घोषित किया जा सकता है और केवल @ एनवायरमेंट एनोटेशन के साथ एनोटेट करके।

@Inject @Path("context:/js/myeffects.js") 
private Asset myEffects;  

@Environmental 
private JavaScriptSupport javaScriptSupport;  
void setupRender() { 
   javaScriptSupport.importJavaScriptLibrary(myEffects); 
}
  • JavaScripSupport केवल एक घटक का उपयोग करके इंजेक्ट किया जा सकता है @Environmentalएनोटेशन। सेवाओं के लिए, हमें एक का उपयोग करने की आवश्यकता है@Inject एनोटेशन या इसे सेवा निर्माता विधि में एक तर्क के रूप में जोड़ें।

@Inject 
private JavaScriptSupport javaScriptSupport; 
public MyServiceImpl(JavaScriptSupport support) { 
   // ... 
}
  • addScript method - यह JavaScriptSupport इंटरफ़ेस के समान है सिवाय इसके कि यह उपयोग करता है addScript विधि और कोड सीधे पृष्ठ के नीचे आउटपुट में जोड़ा जाता है।

void afterRender() { 
   javaScriptSupport.addScript(
      "$('%s').observe('click', hideMe());", container.getClientId()); 
}

जावास्क्रिप्ट ढेर

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

एक डेवलपर अपने स्वयं के स्टैक विकसित कर सकता है JavaScriptStack इंटरफ़ेस और इसे में रजिस्टर AppModule.java। एक बार पंजीकृत होने के बाद, स्टैक का उपयोग करके आयात किया जा सकता है@import एनोटेशन।

@Contribute(JavaScriptStackSource.class) 
public static void addMyStack(
   MappedConfiguration<String, JavaScriptStack> configuration) { 
   
   configuration.addInstance("MyStack", myStack.class); 
}  

@Import(stack = "MyStack") 
public class myPage { 
}

जैसा कि पहले चर्चा की गई है, घटक और पृष्ठ समान हैं सिवाय इसके कि पृष्ठ रूट घटक है और इसमें एक या अधिक बाल घटक शामिल हैं। घटक हमेशा एक पृष्ठ के अंदर रहते हैं और पृष्ठ की लगभग सभी गतिशील कार्यक्षमता करते हैं।

टेपेस्ट्री घटकों जटिल ग्रिड कार्यक्षमता के लिए एक सरल HTML लिंक प्रदान करता है interactive AJAX। एक घटक दूसरे घटक को भी शामिल कर सकता है। टेपेस्ट्री घटकों में निम्नलिखित आइटम होते हैं -

  • Component Class - घटक का मुख्य जावा वर्ग।

  • XML Template- XML ​​टेम्पलेट पेज टेम्पलेट के समान है। घटक वर्ग अंतिम आउटपुट के रूप में टेम्पलेट को प्रस्तुत करता है। कुछ घटकों में टेम्पलेट नहीं हो सकते हैं। इस मामले में, आउटपुट का उपयोग घटक वर्ग द्वारा ही किया जाएगाMarkupWriter कक्षा।

  • Body- पेज टेम्प्लेट के अंदर निर्दिष्ट घटक में कस्टम मार्कअप हो सकता है और इसे "घटक निकाय" कहा जाता है। यदि घटक टेम्पलेट है<body />तत्व, तो <शरीर /> तत्व को घटक के शरीर द्वारा प्रतिस्थापित किया जाएगा। यह XML टेम्प्लेट अनुभाग में पहले चर्चा किए गए लेआउट के समान है।

  • Rendering - प्रतिपादन एक ऐसी प्रक्रिया है जो XML टेम्पलेट और घटक के शरीर को घटक के वास्तविक आउटपुट में बदल देती है।

  • Parameters - घटक और पृष्ठों के बीच संचार बनाने और इस तरह उनके बीच डेटा पास करने के लिए उपयोग किया जाता है।

  • Events- इसके कंटेनर / माता-पिता (पेज या किसी अन्य घटक) के घटकों से कार्यक्षमता को हटाता है। यह पृष्ठ नेविगेशन उद्देश्य में बड़े पैमाने पर उपयोग किया जाता है।

प्रतिपादन

एक घटक का प्रतिपादन पूर्व-परिभाषित चरणों की एक श्रृंखला में किया जाता है। घटक प्रणाली के प्रत्येक चरण में घटक वर्ग में कन्वेंशन या एनोटेशन द्वारा परिभाषित एक संगत विधि होनी चाहिए।

// Using annotaion 
@SetupRender 
void initializeValues() { 
   // initialize values 
}

// using convention 
boolean afterRender() { 
   // do logic 
   return true; 
}

चरण, इसकी विधि का नाम और इसके एनोटेशन नीचे सूचीबद्ध हैं।

टिप्पणी डिफ़ॉल्ट विधि नाम
@SetupRender setupRender ()
@BeginRender beginRender ()
@BeforeRenderTemplate beforeRenderTemplate ()
@BeforeRenderBody beforeRenderBody ()
@AfterRenderBody afterRenderBody ()
@AfterRenderTemplate afterRenderTemplate ()
@AfterRender afterRender ()
@CleanupRender cleanupRender ()

प्रत्येक चरण का एक विशिष्ट उद्देश्य होता है और वे इस प्रकार हैं -

SetupRender

SetupRender किकिंग प्रक्रिया को शुरू करता है। यह आमतौर पर घटक के मापदंडों को स्थापित करता है।

BeginRender

BeginRender घटक को प्रस्तुत करना शुरू करता है। यह आमतौर पर कंपोनेंट के स्टार्ट / स्टार्ट टैग को प्रस्तुत करता है।

BeforeRenderTemplate

पहले XML टेम्प्लेट को सजाने के लिए RenderTemplate का उपयोग किया जाता है, टेम्पलेट के चारों ओर विशेष मार्कअप जोड़ते हैं। यह टेम्प्लेट रेंडरिंग को छोड़ने का विकल्प भी प्रदान करता है।

BeforeRenderBody

पहलेRenderTemplate घटक के शरीर तत्व के प्रतिपादन को छोड़ने के लिए एक विकल्प प्रदान करता है।

AfterRenderBody

AfterRenderBody घटक के शरीर प्रदान करने के बाद कहा जाएगा।

AfterRenderTemplate

AfterRenderTemplate घटक के टेम्पलेट प्रदान किए जाने के बाद कहा जाएगा।

AfterRender

आफ्टरएंडर बिगिनर का समकक्ष है और आमतौर पर क्लोज टैग प्रस्तुत करता है।

CleanupRender

CleanupRender SetupRender का प्रतिरूप है। यह रेंडरिंग प्रक्रिया के दौरान बनाए गए सभी ऑब्जेक्ट को रिलीज़ / डिस्पोज़ करता है।

प्रतिपादन चरणों का प्रवाह केवल आगे नहीं है। यह चरण के रिटर्न मूल्य के आधार पर चरणों के बीच में जाता है।

उदाहरण के लिए, अगर SetupRender विधि गलत है, तो रेंडरिंग क्लीनअपेंडर चरण में और इसके विपरीत। विभिन्न चरणों के बीच प्रवाह की स्पष्ट समझ पाने के लिए, नीचे दिए गए आरेख में प्रवाह की जांच करें।

सरल घटक

आइए हम एक सरल घटक बनाते हैं, हैलो जिसका आउटपुट संदेश "हैलो, टेपेस्ट्री" के रूप में होगा। निम्नलिखित हैलो घटक और उसके टेम्पलेट का कोड है।

package com.example.MyFirstApplication.components;  
public class Hello {  
}
<html  
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
  
   <div> 
      <p>Hello, Tapestry (from component).</p> 
   </div> 
  
</html>

हैलो घटक को पेज टेम्पलेट में कहा जा सकता है -

<html title = "Hello component test page" 
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
<t:hello />  
</html>

इसी तरह, घटक नीचे दिखाए गए अनुसार टेम्पलेट के बजाय मार्कअपविटर का उपयोग करके समान आउटपुट दे सकता है।

package com.example.MyFirstApplication.components; 
  
import org.apache.tapestry5.MarkupWriter; 
import org.apache.tapestry5.annotations.BeginRender;   

public class Hello { 
   @BeginRender 
   void renderMessage(MarkupWriter writer) { 
      writer.write("<p>Hello, Tapestry (from component)</p>"); 
   } 
}

आइए हम घटक टेम्पलेट को बदलते हैं और नीचे कोड कोड में दिखाए गए <body /> तत्व को शामिल करते हैं।

<html>  
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   
   <div> 
      <t:body /> 
   </div> 
</html>

अब, पृष्ठ टेम्पलेट में घटक मार्कअप में शरीर शामिल हो सकता है जैसा कि नीचे दिखाया गया है।

<html title = "Hello component test page" 
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   
   <t:hello> 
      <p>Hello, Tapestry (from page).</p> 
   </t:hello> 
</html>

आउटपुट निम्नानुसार होगा -

<html> 
   <div> 
      <p>Hello, Tapestry (from page).</p> 
   </div> 
</html>

मापदंडों

इन मापदंडों का प्राथमिक उद्देश्य घटक के क्षेत्र और पृष्ठ की एक संपत्ति / संसाधन के बीच संबंध बनाना है। मापदंडों, घटक और इसके संबंधित पृष्ठ का उपयोग करते हुए एक दूसरे के बीच डेटा संवाद और हस्तांतरण। यह कहा जाता हैTwo Way Data Binding

उदाहरण के लिए, उपयोगकर्ता प्रबंधन पृष्ठ में उम्र का प्रतिनिधित्व करने के लिए उपयोग किया जाने वाला एक टेक्स्टबॉक्स घटक पैरामीटर के माध्यम से अपना प्रारंभिक मूल्य (डेटाबेस में उपलब्ध) प्राप्त करता है। फिर से, उपयोगकर्ता की उम्र को अपडेट करने और वापस जमा करने के बाद, घटक उसी पैरामीटर के माध्यम से अपडेट की गई आयु को वापस भेज देगा।

घटक वर्ग में एक नया पैरामीटर बनाने के लिए, एक क्षेत्र घोषित करें और निर्दिष्ट करें @Parameterएनोटेशन। इस @ पैरामीटर में दो वैकल्पिक तर्क हैं, जो हैं -

  • required- पैरामीटर को अनिवार्य बनाता है। टेपेस्ट्री अपवाद प्रदान करता है अगर यह प्रदान नहीं किया जाता है।

  • value - पैरामीटर का डिफ़ॉल्ट मान निर्दिष्ट करता है।

पैरामीटर को पेज टेम्प्लेट में घटक टैग की विशेषताओं के रूप में निर्दिष्ट किया जाना चाहिए। बाइंडिंग एक्सप्रेशन / एक्सपेंशन का उपयोग करके विशेषताओं का मूल्य निर्दिष्ट किया जाना चाहिए, जिसकी चर्चा हमने पहले अध्यायों में की थी। कुछ विस्तार जो हमने पहले सीखे थे -

  • Property expansion (prop:«val») - पेज क्लास की संपत्ति से डेटा प्राप्त करें।

  • Message expansion (message:«val») - index.properties फ़ाइल में परिभाषित कुंजी से डेटा प्राप्त करें।

  • Context expansion (context:«val») - वेब संदर्भ फ़ोल्डर / src / main / webapp से डेटा प्राप्त करें।

  • Asset expansion (asset:«val») - जार फ़ाइल, / मेटा-इन / परिसंपत्तियों में एम्बेडेड संसाधनों से डेटा प्राप्त करें।

  • Symbol expansion (symbol:«val») - AppModule.javafile में परिभाषित प्रतीकों से डेटा प्राप्त करें।

टेपेस्ट्री के कई और उपयोगी विस्तार हैं, जिनमें से कुछ नीचे दिए गए हैं -

  • Literal expansion (literal:«val») - एक शाब्दिक स्ट्रिंग।

  • Var expansion (var:«val») - घटक के एक रेंडर चर को पढ़ने या अद्यतन करने की अनुमति दें।

  • Validate expansion (validate:«val»)- किसी विशेष स्ट्रिंग का उपयोग किसी वस्तु के सत्यापन नियम को निर्दिष्ट करने के लिए किया जाता है। उदाहरण के लिए, मान्य करें: आवश्यक, minLength = 5।

  • Translate (translate:«val») - इनपुट सत्यापन में ट्रांसलेटर क्लास (क्लाइंट-साइड को सर्वर-साइड प्रतिनिधित्व में परिवर्तित करना) निर्दिष्ट करने के लिए उपयोग किया जाता है।

  • Block (block:«val») - टेम्पलेट के भीतर ब्लॉक तत्व की आईडी।

  • Component (component:«val») - टेम्पलेट के भीतर एक अन्य घटक की आईडी।

उपरोक्त सभी विस्तार केवल संपत्ति विस्तार और वार विस्तार को छोड़कर पढ़े जाते हैं। वे पृष्ठ के साथ डेटा का आदान-प्रदान करने के लिए घटक द्वारा उपयोग किया जाता है। विशेषता मान के रूप में विस्तार का उपयोग करते समय,${...}उपयोग नहीं किया जाना चाहिए। इसके बजाय बस डॉलर के बिना विस्तार का उपयोग करें और प्रतीकों का ब्योरा दें।

पैरामीटर का उपयोग करना

हमें नमस्कार घटक को गतिशील रूप से जोड़कर संदेश को प्रस्तुत करने के लिए एक नया घटक, HelloWithParameter बनाएं name घटक वर्ग में पैरामीटर और तदनुसार घटक टेम्पलेट और पेज टेम्पलेट को बदलना।

  • एक नया घटक वर्ग बनाएँ HelloWithParameter.java

  • एक निजी फ़ील्ड जोड़ें और इसे नाम दें @Parameterएनोटेशन। इसे अनिवार्य बनाने के लिए आवश्यक तर्क का उपयोग करें।

@Parameter(required = true) 
private String name;
  • परिणाम के साथ एक निजी फ़ील्ड जोड़ें @Properyएनोटेशन। परिणाम संपत्ति का उपयोग घटक टेम्पलेट में किया जाएगा। घटक टेम्पलेट के साथ एनोटेट किए गए फ़ील्ड तक पहुंच नहीं है@Parameter और केवल उन क्षेत्रों तक पहुँचने में सक्षम हैं जिनके साथ एनोटेट किया गया है @Property। घटक टेम्प्लेट में उपलब्ध चर को रेंडर वेरिएबल्स कहा जाता है।

@Property 
 private String result;
  • एक RenderBody विधि जोड़ें और नाम पैरामीटर से परिणाम संपत्ति में मूल्य की प्रतिलिपि बनाएँ।

@BeginRender 
void initializeValues() { 
   result = name; 
}
  • एक नया घटक टेम्पलेट जोड़ें HelloWithParamter.tml और संदेश को प्रस्तुत करने के लिए परिणाम संपत्ति का उपयोग करें।

<div> Hello, ${result} </div>
  • परीक्षण पृष्ठ (testhello.java) में एक नई संपत्ति, उपयोगकर्ता नाम जोड़ें।

public String getUsername() { 
   return "User1"; 
}
  • पृष्ठ टेम्पलेट में नए बनाए गए घटक का उपयोग करें और के नाम पैरामीटर में उपयोगकर्ता नाम संपत्ति सेट करें HelloWithParameter घटक।

<t:helloWithParameter name = "username" />

पूरी लिस्टिंग इस प्रकार है -

package com.example.MyFirstApplication.components;  

import org.apache.tapestry5.annotations.*;  
public class HelloWithParameter { 
   @Parameter(required = true) 
   private String name; 
     
   @Property 
   private String result; 
   
   @BeginRender 
   void initializeValues() { 
      result = name; 
   } 
}
<html  
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   
   <div> Hello, ${result} </div> 
  
</html>
package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.*;  
public class TestHello { 
   public String getUsername() { 
      return "User1"; 
   } 
}
<html title = "Hello component test page" 
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   <t:helloWithParameter name = "username" />
   
</html>

परिणाम इस प्रकार होगा -

<div> Hello, User1 </div>

उन्नत पैरामीटर

पिछले अध्यायों में, हमने विश्लेषण किया कि कैसे कस्टम घटक में एक सरल पैरामीटर बनाया और उपयोग किया जाए। एक उन्नत पैरामीटर में पूर्ण मार्कअप भी हो सकता है। इस मामले में, मार्कअप को घटक टैग के अंदर निर्दिष्ट किया जाना चाहिए जैसे पृष्ठ टेम्पलेट में उप-भाग। अंतर्निहित घटक में सफलता और विफलता दोनों स्थितियों के लिए मार्कअप है। सफलता का मार्कअप घटक टैग के शरीर के रूप में निर्दिष्ट किया गया है और विफलता का मार्कअप एक का उपयोग करके निर्दिष्ट किया गया हैelseparameter

आइए देखते हैं कि कैसे उपयोग करना है ifघटक। यदि घटक के दो पैरामीटर हैं -

  • test - सरल संपत्ति आधारित पैरामीटर।

  • Else - उन्नत पैरामीटर वैकल्पिक मार्कअप को निर्दिष्ट करने के लिए उपयोग किया जाता है, अगर स्थिति विफल हो जाती है

टेपेस्ट्री निम्नलिखित तर्क का उपयोग करके परीक्षण संपत्ति के मूल्य की जांच करेगा और सही या गलत लौटाएगा। यह कहा जाता हैType Coercion, एक ही प्रकार की वस्तु को उसी प्रकार की सामग्री के साथ दूसरे प्रकार में बदलने का तरीका।

  • यदि डेटा प्रकार है String, "सही" यदि गैर-रिक्त है और शाब्दिक स्ट्रिंग "गलत" (असंवेदनशील) नहीं है।

  • यदि डेटा प्रकार है Number, सत्य अगर गैर शून्य।

  • यदि डेटा प्रकार है Collection, सच्चा अगर गैर-खाली है।

  • यदि डेटा प्रकार है Object, सच (जब तक यह अशक्त नहीं है)।

यदि स्थिति गुजरती है, तो घटक अपने शरीर को प्रदान करता है; अन्यथा, यह दूसरे पैरामीटर के शरीर का प्रतिपादन करता है।

पूरी लिस्टिंग इस प्रकार है -

package com.example.MyFirstApplication.pages; 
public class TestIf { 
   public String getUser() { 
      return "User1"; 
   } 
}

<html title = "If Test Page" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   
   <body> 
      <h1>Welcome!</h1>  
      <t:if test = "user"> 
         Welcome back, ${user} 
         <p:else>
            Please <t:pagelink page = "login">Login</t:pagelink>  
         </p:else> 
      </t:if>
   </body>
   
</html>

घटक ईवेंट / पृष्ठ नेविगेशन

टेपेस्ट्री आवेदन एक है collection of Pagesआपस में बातचीत करना। अब तक, हमने सीखा है कि उनके बीच किसी भी संचार के बिना व्यक्तिगत पृष्ठ कैसे बनाएं। एक घटक ईवेंट का प्राथमिक उद्देश्य सर्वर-साइड ईवेंट्स का उपयोग करके पृष्ठों (पृष्ठों के भीतर) के बीच इंटरैक्शन प्रदान करना है। अधिकांश घटक ईवेंट क्लाइंट-साइड ईवेंट से उत्पन्न होते हैं।

उदाहरण के लिए, जब कोई उपयोगकर्ता किसी पृष्ठ में किसी लिंक पर क्लिक करता है, तो टेपेस्ट्री उसी पृष्ठ को लक्ष्य जानकारी को कॉल करने के बजाय लक्ष्य जानकारी के साथ कॉल करेगा और सर्वर साइड ईवेंट को उठाएगा। टेपेस्ट्री पेज ईवेंट को कैप्चर करेगा, लक्ष्य जानकारी को संसाधित करेगा और लक्ष्य पृष्ठ पर एक सर्वर साइड पुनर्निर्देशन करेगा।

टेपेस्ट्री इस प्रकार है Post/Redirect/Get (RPG) design patternपेज नेविगेशन के लिए। आरपीजी में, जब कोई उपयोगकर्ता एक फ़ॉर्म सबमिट करके पोस्ट अनुरोध करता है, तो सर्वर पोस्ट किए गए डेटा को संसाधित करेगा, लेकिन सीधे प्रतिक्रिया वापस नहीं करता है। इसके बजाय, यह क्लाइंट-साइड रीडायरेक्शन को दूसरे पेज पर करेगा, जो परिणाम को आउटपुट करेगा। एक आरपीजी पैटर्न का उपयोग ब्राउज़र बैक बटन, ब्राउज़र रिफ्रेश बटन आदि के माध्यम से डुप्लिकेट फॉर्म सबमिशन को रोकने के लिए किया जाता है, टेपेस्ट्री निम्नलिखित दो प्रकार के अनुरोध प्रदान करके आरपीजी पैटर्न प्रदान करता है।

  • Component Event Request- इस प्रकार का अनुरोध पृष्ठ में किसी विशेष घटक को लक्षित करता है और घटक के भीतर घटनाओं को बढ़ाता है। यह अनुरोध केवल पुनर्निर्देशन करता है और प्रतिक्रिया का उत्पादन नहीं करता है।

  • Render Request - इन प्रकार के अनुरोध एक पृष्ठ को लक्षित करते हैं और ग्राहक को प्रतिक्रिया वापस भेजते हैं।

घटक घटनाओं और पृष्ठ नेविगेशन को समझने के लिए, हमें टेपेस्ट्री अनुरोध के URL पैटर्न को जानना होगा। दोनों प्रकार के अनुरोधों का URL पैटर्न निम्नानुसार है -

  • Component Event Requests -

/<<page_name_with_path>>.<<component_id|event_id>>/<<context_information>>
  • Render Request -

/<<page_name_with_path>>/<<context_information>>

URL पैटर्न के कुछ उदाहरण हैं -

  • इंडेक्स पेज द्वारा अनुरोध किया जा सकता है https://«domain»/«app»/index

  • यदि अनुक्रमणिका पृष्ठ उप-फ़ोल्डर व्यवस्थापक के तहत उपलब्ध है, तो इसके द्वारा अनुरोध किया जा सकता है https://«domain»/«app»/admin/index

  • यदि उपयोगकर्ता क्लिक करता है ActionLink component साथ में id test इंडेक्स पेज में, तब URL होगा https://«domain»/«app»/index.test

आयोजन

डिफ़ॉल्ट रूप से, टेपेस्ट्री बढ़ती है OnPassivate तथा OnActivateसभी अनुरोधों के लिए घटनाओं। घटक घटना अनुरोध प्रकार के लिए, टेपेस्ट्री घटक के आधार पर अतिरिक्त एक या अधिक घटनाओं को बढ़ाता है। एक्शनलिंक घटक एक्शन इवेंट को बढ़ाता है, जबकि एक फॉर्म कंपोनेंट कई घटनाओं को बढ़ाता है जैसे किValidate, Success, आदि।,

घटनाओं को संबंधित विधि हैंडलर का उपयोग करके पेज क्लास में संभाला जा सकता है। विधि हैंडलर या तो एक विधि नामकरण सम्मेलन के माध्यम से या के माध्यम से बनाया जाता है@OnEventएनोटेशन। विधि नामकरण सम्मेलन का प्रारूप हैOn«EventName»From«ComponentId»

एक्शनलिंक के एक्शन इवेंट के साथ id test निम्नलिखित में से किसी एक विधि द्वारा नियंत्रित किया जा सकता है -

void OnActionFromTest() { 
}  
@OnEvent(component = "test", name = "action") 
void CustomFunctionName() { 
}

यदि विधि नाम में कोई विशेष घटक नहीं है, तो विधि को मेल खाने वाली घटनाओं के साथ सभी घटक के लिए बुलाया जाएगा।

void OnAction() { 
}

OnPassivate और OnActivate Event

OnAassivate इवेंट हैंडलर के लिए संदर्भ जानकारी प्रदान करने के लिए OnPassivate का उपयोग किया जाता है। सामान्य तौर पर, टेपेस्ट्री संदर्भ जानकारी प्रदान करता है और इसे ऑनएक्टिनेटिव हैंडलर में एक तर्क के रूप में इस्तेमाल किया जा सकता है।

उदाहरण के लिए, यदि संदर्भ जानकारी 3 प्रकार की है, तो OnActivate घटना को इस प्रकार कहा जा सकता है -

void OnActivate(int id) { 
}

कुछ परिदृश्य में, संदर्भ जानकारी उपलब्ध नहीं हो सकती है। इस स्थिति में, हम ऑनपेसिनेट इवेंट हैंडलर के माध्यम से ऑनएक्टिव इवेंट हैंडलर को संदर्भ जानकारी प्रदान कर सकते हैं। OnPassivate इवेंट हैंडलर का रिटर्न प्रकार OnActivate इवेंट हैंडलर के तर्क के रूप में उपयोग किया जाना चाहिए।

int OnPassivate() { 
   int id = 3; 
   return id; 
} 
void OnActivate(int id) { 
}

इवेंट हैंडलर रिटर्न वैल्यूज़

टेपेस्ट्री ईवेंट हैंडलर के रिटर्न वैल्यू के आधार पर पेज पुनर्निर्देशन जारी करता है। इवेंट हैंडलर को निम्न में से किसी एक मान को वापस करना चाहिए।

  • Null Response- शून्य मान लौटाता है। टेपेस्ट्री वर्तमान पृष्ठ URL का निर्माण करेगी और क्लाइंट को रीडायरेक्ट के रूप में भेजेगी।

public Object onAction() { 
   return null; 
}
  • String Response- स्ट्रिंग मान लौटाता है। टेपेस्ट्री वैल्यू से मेल खाते पेज का URL बनाएगी और क्लाइंट को रीडायरेक्ट के रूप में भेजेगी।

public String onAction() { 
   return "Index"; 
}
  • Class Response- एक पृष्ठ वर्ग देता है। टेपेस्ट्री लौटे पेज क्लास के यूआरएल का निर्माण करेगी और क्लाइंट को रीडायरेक्ट के रूप में भेजेगी।

public Object onAction() { 
   return Index.class 
}
  • Page Response- @InjectPage के साथ एनोटेट किया गया फ़ील्ड लौटाता है। टेपेस्ट्री इंजेक्ट किए गए पृष्ठ के URL का निर्माण करेगा और क्लाइंट को रीडायरेक्ट के रूप में भेजेगा।

@InjectPage 
private Index index;  

public Object onAction(){ 
   return index; 
}
  • HttpError- HTTPError ऑब्जेक्ट लौटाता है। टेपेस्ट्री क्लाइंट साइड HTTP त्रुटि जारी करेगा।

public Object onAction(){ 
   return new HttpError(302, "The Error message); 
}
  • Link Response- सीधे एक लिंक उदाहरण देता है। टेपेस्ट्री लिंक ऑब्जेक्ट से URL का निर्माण करेगी और क्लाइंट को रीडायरेक्ट के रूप में भेज देगी।

  • Stream Response - लौटता है StreamResponseवस्तु। टेपेस्ट्री सीधे क्लाइंट ब्राउज़र को प्रतिक्रिया के रूप में स्ट्रीम भेज देगा। इसका उपयोग सीधे रिपोर्ट और चित्र बनाने और क्लाइंट को भेजने के लिए किया जाता है।

  • Url Response - लौटता है java.net.URLवस्तु। टेपेस्ट्री ऑब्जेक्ट से संबंधित URL प्राप्त करेगी और क्लाइंट को रीडायरेक्ट के रूप में भेज देगी।

  • Object Response- ऊपर निर्दिष्ट मूल्यों के अलावा किसी भी मान देता है। टेपेस्ट्री एक त्रुटि बढ़ाएगा।

घटना प्रसंग

सामान्य तौर पर, ईवेंट हैंडलर तर्कों का उपयोग करके संदर्भ जानकारी प्राप्त कर सकता है। उदाहरण के लिए, यदि संदर्भ जानकारी 3 प्रकार की है, तो ईवेंट हैंडलर होगा -

Object onActionFromTest(int id) {  
}

टेपेस्ट्री संदर्भ जानकारी को ठीक से संभालती है और तर्कों के माध्यम से इसे प्रदान करती है। कभी-कभी, टेपेस्ट्री प्रोग्रामिंग की जटिलता के कारण इसे ठीक से संभालने में सक्षम नहीं हो सकता है। उस समय, हम पूरी संदर्भ जानकारी प्राप्त कर सकते हैं और स्वयं को संसाधित कर सकते हैं।

Object onActionFromEdit(EventContext context) { 
   if (context.getCount() > 0) { 
      this.selectedId = context.get(0); 
   } else { 
      alertManager.warn("Please select a document."); 
      return null; 
   } 
}

यह अध्याय उन अंतर्निर्मित घटकों के बारे में बताता है, जिनकी टेपेस्ट्री उपयुक्त उदाहरणों के साथ है। टेपेस्ट्री 65 से अधिक निर्मित घटकों का समर्थन करता है। आप कस्टम घटक भी बना सकते हैं। आइए हम कुछ उल्लेखनीय घटकों को विस्तार से कवर करते हैं।

यदि घटक

यदि घटक का उपयोग किसी ब्लॉक को सशर्त रूप से प्रस्तुत करने के लिए किया जाता है। परीक्षण पैरामीटर द्वारा स्थिति की जाँच की जाती है।

पृष्ठ बनाएँ IfSample.java जैसा कि नीचे दिखाया गया है -

package com.example.MyFirstApplication.pages;  

public class Ifsample {
   public String getUser() { 
      return "user1"; 
   } 
}

अब, इस प्रकार एक संबंधित टेम्पलेट फ़ाइल बनाएँ -

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
     
   <h3>If-else component example </h3> 
   <t:if test = "user"> 
      Hello ${user} 
      <p:else>
         <h4> You are not a Tapestry user </h4> 
      </p:else> 
   </t:if> 
</html>

पृष्ठ का अनुरोध करना परिणाम को नीचे दिखाए अनुसार प्रस्तुत करेगा।

Result - http: // localhost: 8080 / MyFirstApplication / ifsample

जब तक और प्रतिनिधि घटक न हों

unless componentअगर ऊपर चर्चा की गई थी कि घटक के ठीक विपरीत है। जबकिdelegate componentअपने आप कोई प्रतिपादन नहीं करता है। इसके बजाय, यह आम तौर पर तत्व को ब्लॉक करने के लिए मार्कअप को दर्शाता है। जब तक और यदि घटक डायनामिक सामग्री को सशर्त रूप से स्वैप करने के लिए प्रतिनिधि और ब्लॉक का उपयोग कर सकते हैं।

पृष्ठ बनाएँ Unless.java निम्नलिखित नुसार।

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.Block; 
import org.apache.tapestry5.annotations.Property; 
import org.apache.tapestry5.ioc.annotations.Inject; 
import org.apache.tapestry5.PersistenceConstants; 
import org.apache.tapestry5.annotations.Persist;  

public class Unless { 
   @Property 
   @Persist(PersistenceConstants.FLASH) 
   private String value;  
   @Property 
   private Boolean bool; 
   @Inject 
   Block t, f, n;  
   
   public Block getCase() { 
      if (bool == Boolean.TRUE ) { 
         return t; 
      } else { 
         return f; 
      } 
   }   
}

अब, इस प्रकार एक संबंधित टेम्पलेट फ़ाइल बनाएँ -

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
  
   <h4> Delegate component </h4> 
   <div class = "div1"> 
      <t:delegate to = "case"/> 
   </div> 
   <h4> If-Unless component </h4>  
   
   <div class = "div1"> 
      <t:if test = "bool"> 
         <t:delegate to = "block:t"/> 
      </t:if> 
      <t:unless test = "bool"> 
         <t:delegate to = "block:notT"/> 
      </t:unless> 
   </div>  
   
   <t:block id = "t"> 
      bool == Boolean.TRUE. 
   </t:block> 
   
   <t:block id = "notT"> 
      bool = Boolean.FALSE. 
   </t:block> 
   
   <t:block id = "f"> 
      bool == Boolean.FALSE. 
   </t:block> 
</html>

पृष्ठ का अनुरोध करना परिणाम को नीचे दिखाए अनुसार प्रस्तुत करेगा।

Result - http: // localhost: 8080 / MyFirstApplication / जब तक

पाश घटक

लूप घटक एक संग्रह आइटम पर लूप करने के लिए मूल घटक है और शरीर को हर मूल्य / पुनरावृत्ति के लिए प्रस्तुत करता है।

नीचे दिखाए अनुसार एक लूप पेज बनाएं -

Loop.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property;  
public class Loop { 
   @Property 
   private int i; 
}

फिर, इसी टेम्पलेट Loop.tml बनाएँ

Loop.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   
   <p>This is sample parameter rendering example...</p> 
   <ol>
      <li t:type = "loop" source = "1..5" value = "var:i">${var:i}</li> 
   </ol> 
</html>

लूप घटक में निम्नलिखित दो पैरामीटर हैं -

  • source- संग्रह स्रोत। 1… 5 एक संपत्ति विस्तार है जिसका उपयोग एक निर्दिष्ट सीमा के साथ एक सरणी बनाने के लिए किया जाता है।

  • var- रेंडर चर। टेम्पलेट के शरीर में वर्तमान मूल्य को प्रस्तुत करने के लिए उपयोग किया जाता है।

पृष्ठ का अनुरोध करना परिणाम को नीचे दिखाए अनुसार प्रस्तुत करेगा -

पेजलिंक घटक

PageLink घटक का उपयोग एक पृष्ठ को एक पृष्ठ से दूसरे पृष्ठ से जोड़ने के लिए किया जाता है। नीचे एक PageLink परीक्षण पृष्ठ बनाएँ -PageLink.java

package com.example.MyFirstApplication.pages;  
   public class PageLink { 
}

फिर, जैसा नीचे दिखाया गया है, उसी अनुरूप फ़ाइल बनाएँ -

PageLink.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   
   <body> 
      <h3><u>Page Link</u> </h3> 
      <div class = "page"> 
         <t:pagelink page = "Index">Click here to navigate Index page</t:pagelink>
         <br/> 
      </div> 
   </body> 
   
</html>

पेजलिंक घटक में एक पृष्ठ पैरामीटर है जो लक्ष्य टेपेस्ट्री पेज को संदर्भित करना चाहिए।

Result - http: // localhost: 8080 / myFirstApplication / pagelink

EventLink घटक

EventLink घटक URL के माध्यम से ईवेंट नाम और संबंधित पैरामीटर भेजता है। जैसा कि नीचे दिखाया गया है एक EventLink पेज क्लास बनाएँ।

EventsLink.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property;  
public class EventsLink { 
   @Property 
   private int x; 
   void onActivate(int count) { 
      this.x = x; 
   } 
   int onPassivate() { 
      return x; 
   } 
   void onAdd(int value) { 
      x += value; 
   }   
}

फिर, इस प्रकार एक "EventLink" टेम्पलेट फ़ाइल बनाएँ -

EventsLink.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   
   <h3> Event link example </h3> 
   AddedCount = ${x}. <br/> 
   <t:eventlink t:event = "add" t:context = "literal:1">
      Click here to add count
   </t:eventlink><br/>  
</html>

EventLink के निम्नलिखित दो पैरामीटर हैं -

  • Event- EventLink घटक में चालू होने वाली घटना का नाम। डिफ़ॉल्ट रूप से, यह घटक की आईडी को इंगित करता है।

  • Context- यह एक वैकल्पिक पैरामीटर है। यह लिंक के लिए संदर्भ को परिभाषित करता है।

Result - http: // localhost: 8080 / myFirstApplication / EventsLink

गणना मूल्य पर क्लिक करने के बाद, पृष्ठ URL में ईवेंट का नाम प्रदर्शित करेगा जैसा कि निम्न आउटपुट स्क्रीनशॉट में दिखाया गया है।

ActionLink घटक

ActionLink घटक EventLink घटक के समान है, लेकिन यह केवल लक्ष्य घटक आईडी भेजता है। डिफ़ॉल्ट ईवेंट नाम क्रिया है।

नीचे दिखाए अनुसार एक पेज “ActivationLinks.java” बनाएं,

ActivationLinks.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property;  
public class ActivationLinks {  
   @Property 
   private int x;  
   void onActivate(int count) { 
      this.x = x; 
   }  
   int onPassivate() { 
      return x; 
   } 
   void onActionFromsub(int value) { 
      x -= value; 
   } 
}

अब, नीचे दिखाए अनुसार एक संबंधित टेम्पलेट फ़ाइल बनाएं -

ActivationLinks.tml

<html t:type = "Newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   
   <div class = "div1"> 
      Count = ${count}. <br/> 
      <t:actionlink t:id = "sub" t:context = "literal:1">
         Decrement
      </t:actionlink><br/> 
   </div> 
   
</html>

यहां ही OnActionFromSub एक्शनलिंक घटक पर क्लिक करने पर विधि को बुलाया जाएगा।

Result - http: // localhost: 8080 / myFirstApplication / ActivationsLink

चेतावनी घटक

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

निम्नलिखित कार्यक्रम में दिखाए गए अनुसार एक पृष्ठ "अलर्ट" बनाएं।

Alerts.java

package com.example.MyFirstApplication.pages;  

public class Alerts { 
   public String getUser() { 
      return "user1"; 
   } 
}

फिर, इस प्रकार एक संबंधित टेम्पलेट फ़ाइल बनाएं -

Alerts.tml

<html t:type = "Newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"  
   xmlns:p = "tapestry:parameter">  
   
   <h3>Alerts</h3> 
   <div class = "alert alert-info"> 
      <h5> Welcome ${user} </h5> 
   </div>
   
</html>

अलर्ट में तीन गंभीरता स्तर होते हैं, जो हैं -

  • Info
  • Warn
  • Error

उपरोक्त टेम्पलेट एक सूचना चेतावनी का उपयोग करके बनाया गया है। इसे के रूप में परिभाषित किया गया हैalert-info। आप आवश्यकता के आधार पर अन्य गंभीरता बना सकते हैं।

पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -

http://localhost:8080/myFirstApplication/Alerts

Form Componentउपयोगकर्ता इनपुट के लिए टेपेस्ट्री पेज में एक फॉर्म बनाने के लिए उपयोग किया जाता है। एक फॉर्म में टेक्स्ट फ़ील्ड, दिनांक फ़ील्ड, चेकबॉक्स फ़ील्ड, चयन विकल्प, सबमिट बटन और बहुत कुछ हो सकता है।

यह अध्याय कुछ उल्लेखनीय रूप के घटकों के बारे में विस्तार से बताता है।

चेकबॉक्स घटक

एक चेकबॉक्स घटक का उपयोग दो परस्पर अनन्य विकल्पों के बीच चयन करने के लिए किया जाता है। नीचे दिखाए गए अनुसार चेकबॉक्स का उपयोग करके एक पेज बनाएं -

Checkbox.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property;  

public class Checkbox { 
   @Property 
   private boolean check1; 
   
   @Property 
   private boolean check2; 
}

अब, एक संबंधित टेम्पलेट बनाएं Checkbox.tml जैसा कि नीचे दिखाया गया है -

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   
   <h3> checkbox component</h3>  
   <t:form> 
      <t:checkbox t:id = "check1"/> I have a bike <br/> 
      <t:checkbox t:id = "check2"/> I have a car 
   </t:form>  
   
</html>

यहां, चेकबॉक्स पैरामीटर आईडी संबंधित बूलियन मान से मेल खाता है।

Result - पृष्ठ का अनुरोध करने के बाद, http: // localhost: 8080 / myFirstApplication / चेकबॉक्स यह निम्नलिखित परिणाम का उत्पादन करता है।

TextField घटक

TextField घटक उपयोगकर्ता को पाठ की एक पंक्ति को संपादित करने की अनुमति देता है। पृष्ठ बनाएँText जैसा की नीचे दिखाया गया।

Text.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property; 
import org.apache.tapestry5.corelib.components.TextField;public class Text {  
   @Property 
   private String fname;  
   @Property 
   private String lname; 
}

फिर, नीचे दिखाए अनुसार एक संबंधित टेम्पलेट बनाएं - Text.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   <p> Form application </p>
   
   <body>  
      <h3> Text field created from Tapestry component </h3> 
      <t:form>  
         <table> 
            <tr> 
               <td> 
                  Firstname: </td> <td><t:textfield t:id = "fname" /> 
               </td> 
               <td>Lastname: </td> <td> <t:textfield t:id = "lname" /> </td> 
            </tr> 
         </table>  
      </t:form>  
   </body> 
   
</html>

यहां, पाठ पृष्ठ में एक संपत्ति नाम शामिल है fname तथा lname। घटक आईडी के गुणों द्वारा पहुँचा जाता है।

पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -

http://localhost:8080/myFirstApplication/Text

PasswordField घटक

PasswordField पासवर्ड के लिए एक विशेष टेक्स्ट फ़ील्ड प्रविष्टि है। एक पेज पासवर्ड बनाएं जैसा कि नीचे दिखाया गया है -

Password.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property; 
import org.apache.tapestry5.corelib.components.PasswordField;  

public class Password {  
   @Property 
   private String pwd; 
}

अब, एक संबंधित टेम्पलेट फ़ाइल बनाएं जैसा कि नीचे दिखाया गया है -

Password.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   <p> Form application </p>  
   <h3> Password field created from Tapestry component </h3> 
   
   <t:form> 
      <table> 
         <tr> 
            <td> Password: </td> 
            <td><t:passwordfield t:id = "pwd"/> </td> 
         </tr> 
      </table> 
   </t:form>
   
</html>

यहां, PasswordField घटक में पैरामीटर आईडी है, जो संपत्ति को इंगित करता है pwd। पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -

http://localhost:8080/myFirstApplication/Password

TextArea घटक

TextArea घटक एक बहु-पंक्ति इनपुट पाठ नियंत्रण है। नीचे दिखाए अनुसार एक पृष्ठ TxtArea बनाएँ।

TxtArea.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property; 
import org.apache.tapestry5.corelib.components.TextArea;  

public class TxtArea {  
   @Property 
   private String str;  
}

फिर, एक संबंधित टेम्पलेट फ़ाइल बनाएं जैसा कि नीचे दिखाया गया है।

TxtArea.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   <h3>TextArea component </h3>
   
   <t:form>
      <table>
         <tr> 
            <td><t:textarea t:id = "str"/>
            </td>
         </tr>
      </table>
   </t:form>
   
</html>

यहाँ, TextArea घटक पैरामीटर id गुण "str" ​​की ओर इशारा करता है। पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -

http://localhost:8080/myFirstApplication/TxtArea**

घटक का चयन करें

चयन घटक में विकल्पों की एक ड्रॉप-डाउन सूची है। एक पेज SelectOption बनाएँ जैसा कि नीचे दिखाया गया है।

SelectOption.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property; 
import org.apache.tapestry5.corelib.components.Select;  

public class SelectOption { 
   @Property 
   private String color0; 
   
   @Property 
   
   private Color1 color1; 
   public enum Color1 { 
      YELLOW, RED, GREEN, BLUE, ORANGE 
   } 
}

फिर, एक समान टेम्पलेट बनाएं जो निम्नानुसार है -

SelectOption.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   <p> Form application </p>
   <h3> select component </h3>  
   
   <t:form> 
      <table> 
         <tr> 
            <td> Select your color here: </td> 
            <td> <select t:type = "select" t:id = "color1"></select></td> 
         </tr> 
      </table> 
   </t:form>
   
</html>

यहां, Select घटक के दो पैरामीटर हैं -

  • Type - संपत्ति का प्रकार एक एनम है।

  • Id - टेपेस्ट्री संपत्ति "color1" के लिए ईद अंक।

पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -

http://localhost:8080/myFirstApplication/SelectOption

रेडियोग्रुप घटक

रेडियोग्रुप घटक रेडियो घटकों के लिए एक कंटेनर समूह प्रदान करता है। रेडियो और रेडियोग्रुप घटक किसी वस्तु की संपत्ति को अद्यतन करने के लिए एक साथ काम करते हैं। इस घटक को अन्य रेडियो घटकों के चारों ओर लपेटना चाहिए। जैसा कि नीचे दिखाया गया है एक नया पेज “Radiobutton.java” बनाएं -

Radiobutton.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.PersistenceConstants; 
import org.apache.tapestry5.annotations.Persist; 
import org.apache.tapestry5.annotations.Property;  

public class Radiobutton {  
   @Property 
   @Persist(PersistenceConstants.FLASH)  
   private String value; 
}

फिर, एक संबंधित टेम्पलेट फ़ाइल बनाएं जैसा कि नीचे दिखाया गया है -

Radiobutton.tml

<html t:type = "Newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   <h3>RadioGroup component </h3> 
   
   <t:form>
      <t:radiogroup t:id = "value">
         <t:radio t:id = "radioT" value = "literal:T" label = "Male" /> 
         <t:label for = "radioT"/>    
         <t:radio t:id = "radioF" value = "literal:F" label = "Female"/> 
         <t:label for = "radioF"/>   
      </t:radiogroup>
   </t:form>
   
</html>

यहां, रेडियोग्रुप घटक आईडी संपत्ति "मूल्य" के साथ बाध्यकारी है। पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा।

http://localhost:8080/myFirstApplication/Radiobutton

घटक प्रस्तुत करें

जब उपयोगकर्ता सबमिट बटन पर क्लिक करता है, तो फॉर्म टैग की कार्रवाई सेटिंग में निर्दिष्ट पते पर भेजा जाता है। पृष्ठ बनाएँSubmitComponent जैसा की नीचे दिखाया गया।

package com.example.MyFirstApplication.pages;  
import org.apache.tapestry5.annotations.InjectPage;  

public class SubmitComponent { 
   @InjectPage 
   private Index page1; 
   Object onSuccess() { 
      return page1; 
   }     
}

अब, नीचे दिखाए अनुसार एक संबंधित टेम्पलेट फ़ाइल बनाएं।

SubmitComponent.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   <h3>Tapestry Submit component </h3> 
   
   <body> 
      <t:form> 
         <t:submit t:id = "submit1" value = "Click to go Index"/> 
      </t:form> 
   </body>
   
</html>

यहां, सबमिट करें घटक इंडेक्स पेज पर मूल्य जमा करता है। पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -

http://localhost:8080/myFirstApplication/SubmitComponent

फॉर्म मान्यता

क्लाइंट के सभी आवश्यक डेटा दर्ज करने और फिर फॉर्म जमा करने के बाद सर्वर पर फॉर्म सत्यापन सामान्य रूप से होता है। यदि क्लाइंट द्वारा दर्ज किया गया डेटा गलत था या बस गायब था, तो सर्वर को क्लाइंट को सभी डेटा वापस भेजना होगा और अनुरोध करना होगा कि फॉर्म को सही जानकारी के साथ फिर से जमा किया जाए।

हमें सत्यापन की प्रक्रिया को समझने के लिए निम्नलिखित सरल उदाहरण पर विचार करें।

पृष्ठ बनाएँ Validate जैसा की नीचे दिखाया गया।

Validate.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property; 
import org.apache.tapestry5.PersistenceConstants; 
import org.apache.tapestry5.annotations.Persist;  

public class Validate {  
   @Property 
   @Persist(PersistenceConstants.FLASH) 
   private String firstName; 
   
   @Property 
   @Persist(PersistenceConstants.FLASH) 
   private String lastName; 
}

अब, नीचे दिखाए अनुसार एक संबंधित टेम्पलेट फ़ाइल बनाएं।

Validate.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
  
   <t:form> 
      <table> 
         <tr> 
            <td><t:label for = "firstName"/>:</td> 
            <td><input t:type = "TextField" t:id = "firstName" 
            t:validate = "required, maxlength = 7" size = "10"/></td>   
         </tr> 
         <tr> 
            <td><t:label for = "lastName"/>:</td> 
            <td><input t:type = "TextField" t:id = "lastName" 
            t:validate = "required, maxLength = 5" size = "10"/></td>  
         </tr>  
      </table>  
      <t:submit t:id = "sub" value =" Form validation"/>  
   </t:form>
   
</html>

प्रपत्र सत्यापन के निम्नलिखित महत्वपूर्ण पैरामीटर हैं -

  • Max - अधिकतम मान को परिभाषित करता है, उदाहरण के लिए = «अधिकतम मूल्य, 20»।

  • MaxDate- maxDate को परिभाषित करता है, उदाहरण के लिए = «अधिकतम तिथि, 06/09/2013»। इसी तरह, आप MinDate को भी असाइन कर सकते हैं।

  • MaxLength - उदाहरण के लिए अधिकतम गति = «अधिकतम लंबाई, 80»।

  • Min - न्यूनतम।

  • MinLength - उदाहरण के लिए न्यूनतम लंबाई = «न्यूनतम लंबाई, 2»।

  • Email - ईमेल सत्यापन जो या तो मानक ईमेल regexp का उपयोग करता है ^ \ w [._ \ w] * \ w @ \ w [-__ \ w] * \ w \। \ W2,6 $ या कोई नहीं।

पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -

http://localhost:8080/myFirstApplication/Validate

AJAX के लिए खड़ा है Asynchronous JavaScript and XML। यह बेहतर, तेज और अधिक इंटरैक्टिव वेब एप्लिकेशन बनाने के लिए एक तकनीक है जिसकी मदद सेXML, JSON, HTML, CSS, तथा JavaScript। AJAX आपको वेब पेज को पुनः लोड किए बिना एसिंक्रोनस रूप से डेटा भेजने और प्राप्त करने की अनुमति देता है, इसलिए यह तेज़ है।

जोन कंपोनेंट

एक जोन कंपोनेंट का इस्तेमाल कंटेंट (मार्कअप) के साथ-साथ कंटेंट की स्थिति को भी बताने के लिए किया जाता है। ज़ोन कंपोनेंट के बॉडी का उपयोग आंतरिक रूप से टेपेस्ट्री द्वारा सामग्री उत्पन्न करने के लिए किया जाता है। एक बार जब डायनेमिक कंटेंट जेनरेट हो जाता है, टेपेस्ट्री इसे क्लाइंट को भेजेगा, डेटा को सही जगह पर रेंडर करेगा, यूजर का ध्यान खींचने के लिए HTML को ट्रिगर और एनिमेट करेगा।

यह जोन घटक एक EventLink घटक के साथ प्रयोग किया जाता है। एक EventLink के पास इसका उपयोग करके किसी विशेष क्षेत्र में टाई करने का विकल्प हैt:zoneजिम्मेदार बताते हैं। एक बार ज़ोन EventLink में कॉन्फ़िगर हो जाने के बाद, EventLink पर क्लिक करने से ज़ोन अपडेट चालू हो जाएगा। इसके अलावा, EventLink घटनाओं (रिफ्रेशोन) का उपयोग गतिशील डेटा की पीढ़ी को नियंत्रित करने के लिए किया जा सकता है।

AJAX का एक सरल उदाहरण इस प्रकार है -

AjaxZone.tml

<html t:type = "Newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   
   <body> 
      <h1>Ajax time zone example</h1>  
      <div class = "div1">  
         <a t:type = "eventlink" t:event = "refreshZone" href = "#" 
            t:zone = "timeZone">Ajax Link </a><br/><br/> 
         <t:zone t:id = "timeZone" id = "timeZone">Time zone: ${serverTime}</t:zone> 
      </div>  
   </body>
   
</html>

AjaxZone.java

package com.example.MyFirstApplication.pages;  

import java.util.Date; 
import org.apache.tapestry5.annotations.InjectComponent; 
import org.apache.tapestry5.corelib.components.Zone; 
import org.apache.tapestry5.ioc.annotations.Inject; 
import org.apache.tapestry5.services.Request;  

public class AjaxZone { 
   @Inject 
   private Request request; 
   
   @InjectComponent 
   private Zone timeZone; 
   
   void onRefreshPage() { 
   } 
   
   Object onRefreshZone() { 
      return request.isXHR() ? timeZone.getBody() : null; 
   } 
   
   public Date getServerTime() { 
      return new Date(); 
   } 
}

परिणाम यहाँ दिखाई देगा: http: // localhost: 8080 / MyFirstApplication / AjaxZone

इस अध्याय में, हम के एकीकरण के बारे में चर्चा करेंगे BeanEditForm तथा Grid componentहाइबरनेट के साथ। हाइबरनेट को हाइबरनेट मॉड्यूल के माध्यम से टेपेस्ट्री में एकीकृत किया जाता है। हाइबरनेट मॉड्यूल को सक्षम करने के लिए, टेपेस्ट्री-हाइबरनेट निर्भरता और वैकल्पिक रूप से जोड़ेंhsqldb में pom.xmlफ़ाइल। अब, के माध्यम से हाइबरनेट कॉन्फ़िगर करेंhibernate.cfg.xml फ़ाइल को संसाधन फ़ोल्डर की जड़ में रखा गया।

pom.xml (आंशिक)

<dependency> 
   <groupId>org.apache.tapestry</groupId> 
   <artifactId>tapestry-hibernate</artifactId> 
   <version>${tapestry-release-version}</version> 
</dependency>  

<dependency> 
   <groupId>org.hsqldb</groupId> 
   <artifactId>hsqldb</artifactId> 
   <version>2.3.2</version> 
</dependency>

Hibernate.cfg.xml

<!DOCTYPE hibernate-configuration PUBLIC 
   "-//Hibernate/Hibernate Configuration DTD 3.0//EN" 
   "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> 

<hibernate-configuration> 
   <session-factory> 
      <property name = "hibernate.connection.driver_class">
         org.hsqldb.jdbcDriver
      </property> 
      <property name = "hibernate.connection.url">
         jdbc:hsqldb:./target/work/sampleapp;shutdown = true
      </property> 
      <property name = "hibernate.dialect">
         org.hibernate.dialect.HSQLDialect
      </property> 
      
      <property name = "hibernate.connection.username">sa</property> 
      <property name = "hibernate.connection.password"></property> 
      <property name = "hbm2ddl.auto">update</property>
      <property name = "hibernate.show_sql">true</property> 
      <property name = "hibernate.format_sql">true</property> 
   </session-factory> 
</hibernate-configuration>

आइए देखते हैं कि कैसे बनाया जाता है employee add page BeanEditForm घटक और का उपयोग कर employee list pageग्रिड घटक का उपयोग करना। दृढ़ता परत को हाइबरनेट मॉड्यूल द्वारा नियंत्रित किया जाता है।

कर्मचारी वर्ग बनाएं और इसे @ एंटिटी एनोटेशन से सजाएं। फिर, संबंधित फ़ील्ड के लिए सत्यापन एनोटेशन जोड़ें और आईडी फ़ील्ड के लिए संबंधित एनोटेशन @Id और @GeneratedValue हाइबरनेट करें। इसके अलावा, एनुम प्रकार के रूप में लिंग बनाएं।

Employee.java

package com.example.MyFirstApplication.entities;  

import javax.persistence.Entity; 
import javax.persistence.GeneratedValue; 
import javax.persistence.GenerationType; 
import javax.persistence.Id;  
import org.apache.tapestry5.beaneditor.NonVisual; 
import org.apache.tapestry5.beaneditor.Validate;  

@Entity 
public class Employee {  
   @Id 
   @GeneratedValue(strategy = GenerationType.IDENTITY) 
   @NonVisual 
   public Long id;  

   @Validate("required") 
   public String firstName;  
 
   @Validate("required") 
   public String lastName; 

   @Validate("required") 
   public String userName;  

   @Validate("required") 
   public String password;  

   @Validate("required") 
   public String email;  
   public String phone;  

   @Validate("required") 
   public String Street;  

   @Validate("required") 
   public String city;  

   @Validate("required") 
   public String state;  

   @Validate("required,regexp=^\\d{5}(-\\d{4})?$") 
   public String zip; 
} 
Gender.java (enum)  
package com.example.MyFirstApplication.data;  

public enum Gender { 
   Male, Female 
}

कर्मचारी सूची पृष्ठ बनाएँ, ListEmployee.java नए फोल्डर में कर्मचारी पेज के नीचे और संबंधित टेम्पलेट फ़ाइल ListEmployee.tml पर /src/main/resources/pages/employeeफ़ोल्डर। टेपेस्ट्री बार-बार डेटा को हटाकर उप फ़ोल्डर्स के लिए एक छोटा URL प्रदान करता है।

उदाहरण के लिए, ListEmployee पृष्ठ को एक सामान्य URL - (/ कर्मचारी / कर्मचारी) और छोटे URL - (/ कर्मचारी / सूची) द्वारा पहुँचा जा सकता है।

सूची पृष्ठ में हाइबरनेट सत्र को इंजेक्ट करें @Inject एनोटेशन का उपयोग करते हुए। एक संपत्ति को परिभाषित करेंgetEmployeesसूची पृष्ठ में और इंजेक्शन सत्र वस्तु का उपयोग करने वाले कर्मचारियों के साथ इसे आबाद करें। कर्मचारी वर्ग के लिए कोड पूरा करें जैसा कि नीचे दिखाया गया है।

ListEmployee.java

package com.example.MyFirstApplication.pages.employee;  

import java.util.List;  
import org.apache.tapestry5.annotations.Import; 
import org.apache.tapestry5.ioc.annotations.Inject;  
import org.hibernate.Session; 
import com.example.MyFirstApplication.entities.Employee; 
import org.apache.tapestry5.annotations.Import;  
@Import(stylesheet="context:mybootstrap/css/bootstrap.css") 

public class ListEmployee { 
   @Inject 
   private Session session; 
   
   public List<Employee> getEmployees() { 
      return session.createCriteria(Employee.class).list(); 
   } 
}

ListEmployee वर्ग के लिए टेम्प्लेट फ़ाइल बनाएँ। टेम्पलेट में दो मुख्य घटक होंगे, जो हैं -

  • PageLink - कर्मचारी लिंक पेज बनाएं।

  • Grid- कर्मचारी विवरण प्रस्तुत करने के लिए उपयोग किया जाता है। ग्रिड घटक में कर्मचारी सूची को इंजेक्ट करने के लिए स्रोत होते हैं और इसमें शामिल किए जाने वाले क्षेत्रों को शामिल करने के लिए विशेषताएँ शामिल होती हैं।

ListEmployee.tml (सभी कर्मचारियों की सूची)

<html t:type = "simplelayout" title = "List Employee" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"> 
   <h1>Employees</h1> 
   
   <ul> 
      <li><t:pagelink page = "employee/create">Create new employee</t:pagelink></li> 
   </ul>  
   <t:grid source = "employees" 
      include = "userName,firstName,lastName,gender,dateOfBirth,phone,city,state"/>  
</html>

कर्मचारी निर्माण टेम्प्लेट फ़ाइल बनाएँ और बीनएडिटफार्म घटक शामिल करें। घटक में निम्नलिखित विशेषताएं हैं -

  • object - इसमें शामिल हैं।

  • reorder - प्रदान किए जाने वाले क्षेत्रों के क्रम को परिभाषित करता है।

  • submitlabel - फॉर्म सबमिशन बटन का मैसेज

पूरा कोडिंग इस प्रकार है -

<html t:type = "simplelayout" title = "Create New Address" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd">  
   <t:beaneditform  
      object = "employee"  
      submitlabel = "message:submit-label" 
      reorder = "userName,password,firstName,lastName,
      dateOfBirth,gender,email,phone,s treet,city,state,zip" />  
</html>

कर्मचारी निर्माण वर्ग बनाएं और सत्र, कर्मचारी संपत्ति, सूची पृष्ठ (नेविगेशन लिंक) और घटक की OnSuccess घटना (डेटा को अपडेट करने का स्थान) को परिभाषित करें। सत्र डेटा हाइबरनेट सत्र का उपयोग करके डेटाबेस में बना रहता है।

पूरा कोडिंग इस प्रकार है -

package com.example.MyFirstApplication.pages.employee;  

import com.example.MyFirstApplication.entities.Employee; 
import com.example.MyFirstApplication.pages.employee.ListEmployee; 
import org.apache.tapestry5.annotations.InjectPage; 
import org.apache.tapestry5.annotations.Property;  
import org.apache.tapestry5.hibernate.annotations.CommitAfter; 
import org.apache.tapestry5.ioc.annotations.Inject; 
import org.hibernate.Session;  

public class CreateEmployee { 
   @Property 
   private Employee employee;  
   @Inject 
   private Session session;  
   @InjectPage 
   private ListEmployee listPage;  
   @CommitAfter 
   Object onSuccess() { 
      session.persist(employee);  
      return listPage; 
   } 
}

जोड़ें CreateEmployee.propertiesफ़ाइल और फॉर्म सत्यापन में उपयोग किए जाने वाले संदेश को शामिल करें। पूरा कोड इस प्रकार है -

zip-regexp=^\\d{5}(-\\d{4})?$ 
zip-regexp-message = Zip Codes are five or nine digits. Example: 02134 or 901251655. 
submit-label = Create Employee

कर्मचारी निर्माण पृष्ठ और सूची पृष्ठ का स्क्रीनशॉट नीचे दिखाया गया है -

प्रत्येक वेब एप्लिकेशन के पास कुछ उपयोगकर्ता डेटा जैसे उपयोगकर्ता ऑब्जेक्ट, उपयोगकर्ता प्राथमिकताएं, आदि संग्रहीत करने का कोई तरीका होना चाहिए। उदाहरण के लिए, शॉपिंग कार्ट एप्लिकेशन में, उपयोगकर्ता की चयनित वस्तुओं / उत्पादों को अस्थायी बकेट (कार्ट) में तब तक सहेजा जाना चाहिए, जब तक उपयोगकर्ता पसंद न करें। उत्पादों को खरीदने के लिए। हम किसी डेटाबेस में आइटम सहेज सकते हैं, लेकिन यह बहुत महंगा होगा क्योंकि सभी उपयोगकर्ता चयनित आइटम खरीदने नहीं जा रहे हैं। इसलिए, हमें वस्तुओं को स्टोर / स्थिर रखने के लिए एक अस्थायी व्यवस्था की आवश्यकता है। अपाचे टेपेस्ट्री डेटा को जारी रखने के दो तरीके प्रदान करता है और वे हैं -

  • हठ पेज डेटा
  • सत्र भंडारण

दोनों के अपने फायदे और सीमाएँ हैं। हम इसे निम्नलिखित खंडों में जाँचेंगे।

दृढ़ता पेज डेटा

Persistence Page Data अनुरोधों के बीच एकल पृष्ठ में डेटा को जारी रखने के लिए एक सरल अवधारणा है और इसे इस रूप में भी कहा जाता है Page Level Persistence। यह का उपयोग करके किया जा सकता है@Persist एनोटेशन।

@Persist 
public int age;

एक बार जब @Persist के साथ किसी फ़ील्ड को एनोटेट किया जाता है, तो फ़ील्ड का मान पूरे अनुरोध पर जारी रहेगा और यदि अनुरोध के दौरान मान बदल जाता है, तो इसे अगली बार एक्सेस किए जाने पर प्रतिबिंबित किया जाएगा। Apache टेपेस्ट्री @Persist अवधारणा को लागू करने के लिए पांच प्रकार की रणनीति प्रदान करती है। वे इस प्रकार हैं -

  • Session Strategy - डेटा सत्र का उपयोग करके कायम है और यह एक डिफ़ॉल्ट रणनीति है।

  • Flash Strategy- डेटा सत्र के रूप में अच्छी तरह से प्रयोग किया जाता है, लेकिन यह एक बहुत कम रहता है। डेटा केवल एक बाद के अनुरोध में उपलब्ध होगा।

@Persist(PersistenceConstants.FLASH) 
private int age;
  • Client Strategy - डेटा क्लाइंट साइड में बना रहता है जैसे URL क्वेरी स्ट्रिंग, फॉर्म में छिपा फील्ड, आदि।

@Persist(PersistenceConstants.FLASH) 
private int age;
  • Hibernate Entity Strategy- डेटा को हाइबरनेट मॉड्यूल का उपयोग इकाई के रूप में किया जाता है। इकाई को हाइबरनेट में संग्रहीत किया जाएगा और इसके संदर्भ (जावा वर्ग का नाम और इसकी प्राथमिक कुंजी) को टोकन के रूप में सहेजा जाएगाHttpSession। HttpSession में उपलब्ध टोकन का उपयोग करके इकाई को बहाल किया जाएगा।

@Persist(HibernatePersistenceConstants.ENTITY) 
private Category category;
  • JPA Entity Strategy- डेटा एक जेपीए मॉड्यूल का उपयोग करके बना रहता है। यह केवल एंटिटी को स्टोर करने में सक्षम होगा।

@Persist(JpaPersistenceConstants.ENTITY) 
private User user;

सत्र भंडारण

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

  • Session Store Object - जटिल वस्तु को संग्रहीत करने के लिए उपयोग किया जाता है।

  • Session Attributes - सरल मूल्यों को संग्रहीत करने के लिए उपयोग किया जाता है।

सेशन स्टोर ऑब्जेक्ट (SSO)

एक SSO का उपयोग करके बनाया जा सकता है @SessionStoreएनोटेशन। SSO ऑब्जेक्ट के प्रकार का उपयोग करके ऑब्जेक्ट को स्टोर करेगा। उदाहरण के लिए,Cart Objectटोकन के रूप में कार्ट क्लास नाम का उपयोग करके संग्रहीत किया जाएगा। इसलिए, किसी भी जटिल वस्तु को एक बार एक एप्लिकेशन (प्रति उपयोगकर्ता) में संग्रहीत किया जा सकता है।

public class MySSOPage { 
   @SessionState 
   private ShoppingCart cart; 
}

एक एसएसओ एक विशेष स्टोर है और इसका उपयोग केवल जटिल / विशेष वस्तु को स्टोर करने के लिए किया जाना चाहिए। एक एसएसओ का उपयोग करके सरल डेटा प्रकारों को भी संग्रहीत किया जा सकता है, लेकिन स्ट्रिंग की तरह सरल डेटा प्रकारों को संग्रहीत करने से यह एप्लिकेशन में केवल एक "स्ट्रिंग" मान संग्रहीत करता है। अनुप्रयोग में एकल "स्ट्रिंग" मान का उपयोग करना संभव नहीं है। आप साधारण डेटा प्रकारों का उपयोग कर सकते हैं क्योंकि Apache Tapestry सत्र विशेषताएँ प्रदान करता है।

सत्र की विशेषताएँ

सत्र विशेषताएँ डेटा को इसके प्रकार के बजाय नाम से संग्रहीत करने में सक्षम बनाती हैं।

public class MyPage { 
   @SessionAttribute  
   private String loggedInUsername; 
}

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

public class MyPage { 
   @SessionAttribute("loggedInUserName") 
   private String userName; 
}

सत्र संदर्भ के रूप में नाम का उपयोग करने में एक मुख्य मुद्दा यह है कि हम गलती से एक से अधिक वर्ग / पृष्ठ में एक ही नाम का उपयोग कर सकते हैं। इस स्थिति में, संग्रहीत डेटा शायद अप्रत्याशित रूप से बदल गया है। इस समस्या को ठीक करने के लिए, वर्ग / पृष्ठ नाम और पैकेज नाम के साथ नाम का उपयोग करना बेहतर होगाcom.myapp.pages.register.email, जहाँ com.myapp.pages पैकेज का नाम है, रजिस्टर पेज / क्लास का नाम है और अंत में ईमेल वेरिएबल (स्टोर किया जाने वाला) नाम है।

इस अध्याय में, हम अपाचे टेपेस्ट्री की कुछ उन्नत विशेषताओं के बारे में विस्तार से चर्चा करेंगे।

नियंत्रण का उलटा

टेपेस्ट्री में निर्मित लाइब्रेरी ऑफ कंट्रोल लाइब्रेरी है। टेपेस्ट्री आईओसी में गहराई से एकीकृत है और अपनी सभी विशेषताओं के लिए आईओसी का उपयोग करता है। टेपेस्ट्री IoC कॉन्फ़िगरेशन कई अन्य IoC कंटेनरों की तरह XML के बजाय जावा पर ही आधारित है। टेपेस्ट्री IoC आधारित मॉड्यूल JAR फ़ाइल में पैक किए गए हैं और बस शून्य कॉन्फ़िगरेशन के साथ क्लासपाथ में गिरा दिए गए हैं। टेपेस्ट्री IoC का उपयोग लपट पर आधारित है, जिसका अर्थ है -

  • दो या तीन तरीकों के छोटे इंटरफेस।

  • दो या तीन मापदंडों के साथ छोटे तरीके।

  • स्पष्ट विधि चालान के बजाय घटनाओं के माध्यम से बेनामी संचार।

मॉड्यूल

मॉड्यूल टेपेस्ट्री एप्लिकेशन की कार्यक्षमता को बढ़ाने का एक तरीका है। टेपेस्ट्री में दोनों अंतर्निहित मॉड्यूल और बड़ी संख्या में तृतीय-पक्ष मॉड्यूल हैं। हाइबरनेट तापस्ट्री द्वारा प्रदान किए जाने वाले गर्म और बहुत उपयोगी मॉड्यूल में से एक है। इसमें JMX, JPA, स्प्रिंग फ्रेमवर्क, JSR 303 बीन सत्यापन, JSON आदि को एकीकृत करने वाले मॉड्यूल भी हैं, जिनमें से कुछ उल्लेखनीय तृतीय-पक्ष मॉड्यूल हैं -

  • Tapestry-Cayenne
  • Tapestry5-googleanalytics
  • गैंग ऑफ़ टेपेस्ट्री 5 - टेपेस्ट्री 5-हाईचर्ट्स
  • गैंग ऑफ़ टेपेस्ट्री 5 - टेपेस्ट्री 5-jqPlot
  • टेपेस्ट्री 5 का गैंग - टेपेस्ट्री 5-जेकरी
  • गैंग ऑफ़ टेपेस्ट्री 5 - टेपेस्ट्री 5-जेक्वेरी-मोबाइल
  • गैंग ऑफ़ टेपेस्ट्री 5 - टेपेस्ट्री 5-पोर्टलेट

रनटाइम अपवाद

टेपेस्ट्री की सबसे अच्छी विशेषता है Detailed Error Reporting। टेपेस्ट्री कला अपवाद रिपोर्टिंग की स्थिति प्रदान करके एक डेवलपर की मदद करता है। टेपेस्ट्री अपवाद रिपोर्ट विस्तृत जानकारी के साथ सरल HTML है। रिपोर्ट को कोई भी आसानी से समझ सकता है। टेपेस्ट्री HTML में त्रुटि दिखाती है और साथ ही एक सादे पाठ में अपवाद को बचाने के साथ दिनांक और समय घटित होता है। इससे डेवलपर को उत्पादन वातावरण में अपवाद की जांच करने में मदद मिलेगी। डेवलपर किसी भी मुद्दे जैसे टूटे हुए टेम्प्लेट, अप्रत्याशित अशक्त मूल्य, बेजोड़ अनुरोध, आदि को ठीक करने के प्रति आश्वस्त रह सकता है।

लाइव क्लास और टेम्प्लेट रीलोडिंग

टेपेस्ट्री को संशोधित किए जाने पर स्वचालित रूप से टेम्प्लेट और कक्षाएं फिर से लोड होंगी। यह सुविधा बिल्ड और परीक्षण चक्र के माध्यम से जाने के बिना अनुप्रयोग परिवर्तनों के तत्काल प्रतिबिंब को सक्षम करती है। साथ ही, यह सुविधा अनुप्रयोग विकास की उत्पादकता में बहुत सुधार करती है।

आवेदन के रूट पैकेज पर विचार करें org.example.myfirstapp। फिर, लोडिंग के लिए निम्न पथों की कक्षाएं स्कैन की जाती हैं।

  • org.example.myfirstapp.pages
  • org.example.myfirstapp.components
  • org.example.myfirstapp.mixins
  • org.example.myfirstapp.base
  • org.example.myfirstapp.services

उत्पादन मोड सेट करके लाइव क्लास को फिर से लोड किया जा सकता है true में AppModule.java

configuration.add(SymbolicConstants.PRODUCTION_MODE,”false”);

इकाई का परीक्षण

यूनिट परीक्षण एक ऐसी तकनीक है जिसके द्वारा व्यक्तिगत पृष्ठों और घटकों का परीक्षण किया जाता है। टेपेस्ट्री इकाई परीक्षण पृष्ठों और घटकों के लिए आसान विकल्प प्रदान करता है।

एक पृष्ठ का परीक्षण इकाई: टेपेस्ट्री एक वर्ग प्रदान करते हैं PageTesterआवेदन का परीक्षण करने के लिए। यह ब्राउज़र और सर्वलेट कंटेनर दोनों के रूप में कार्य करता है। यह सर्वर-साइड में ही ब्राउज़र के बिना पेज को रेंडर करता है और परिणामी दस्तावेज को सही रेंडरिंग के लिए चेक किया जा सकता है। एक साधारण पृष्ठ पर विचार करेंHello, जो हेलो को प्रस्तुत करता है और हैलो टेक्स्ट को आईडी के साथ एक html तत्व के अंदर संलग्न किया जाता है hello_id। इस सुविधा का परीक्षण करने के लिए, हम नीचे दिखाए गए अनुसार पेजटेस्टर का उपयोग कर सकते हैं -

public class PageTest extends Assert { 
   @Test 
   public void test1() { 
      Sring appPackage = "org.example.myfirstapp"; // package name 
      String appName = "App1"; // app name 
      PageTester tester = new PageTester(appPackage, appName, "src/main/webapp"); 
      Document doc = tester.renderPage("Hello"); 
      assertEquals(doc.getElementById("hello_id").getChildText(), "hello"); 
   } 
}

पेजटेस्टर पेज को रेंडर करने के अलावा संदर्भ जानकारी, फॉर्म सबमिशन, लिंक नेविगेशन आदि को शामिल करने का विकल्प भी प्रदान करता है।

एकीकृत परीक्षण

एकीकृत परीक्षण इकाई परीक्षण के रूप में व्यक्तिगत पृष्ठों की जाँच के बजाय एक मॉड्यूल के रूप में अनुप्रयोग का परीक्षण करने में मदद करता है। एकीकृत परीक्षण में, कई मॉड्यूल को एक इकाई के रूप में एक साथ परीक्षण किया जा सकता है। टेपेस्ट्री नामक एक छोटा पुस्तकालय प्रदान करता हैTapestry Test Utilitiesएकीकृत परीक्षण करने के लिए। यह पुस्तकालय परीक्षण करने के लिए सेलेनियम परीक्षण उपकरण के साथ एकीकृत करता है। पुस्तकालय एक आधार वर्ग प्रदान करता हैSeleniumTestCase, जो सेलेनियम सर्वर, सेलेनियम क्लाइंट और जेट्टी इंस्टेंस को शुरू और प्रबंधित करता है।

एकीकृत परीक्षण का एक उदाहरण इस प्रकार है -

import org.apache.tapestry5.test.SeleniumTestCase; 
import org.testng.annotations.Test;  

public class IntegrationTest extends SeleniumTestCase { 
   @Test 
   public void persist_entities() {  
      open("/persistitem"); 
      assertEquals(getText("//span[@id='name']").length(), 0); 
      clickAndWait("link = create item"); 
      assertText("//span[@id = 'name']", "name"); 
   } 
}

विकास डैशबोर्ड

विकास डैशबोर्ड डिफ़ॉल्ट पृष्ठ है जिसका उपयोग आपके एप्लिकेशन में समस्याओं को पहचानने / हल करने के लिए किया जाता है। डैशबोर्ड यूआरएल द्वारा एक्सेस किया जाता हैhttp://localhost:8080/myfirstapp/core/t5dashboard। डैशबोर्ड एप्लिकेशन में उपलब्ध सभी पृष्ठों, सेवाओं और घटक पुस्तकालयों को दिखाता है।

प्रतिक्रिया संपीड़न

टेपेस्ट्री स्वचालित रूप से प्रतिक्रिया का उपयोग कर संपीड़ित करता है GZIP compressionऔर इसे क्लाइंट को स्ट्रीम करें। यह सुविधा नेटवर्क ट्रैफ़िक को कम करेगी और पृष्ठ के तेज़ी से वितरण में सहायता करेगी। प्रतीक का उपयोग करके संपीड़न को कॉन्फ़िगर किया जा सकता हैtapestry.min-gzip-sizeAppModule.java में। डिफ़ॉल्ट मान 100 बाइट्स है। एक बार जब प्रतिक्रिया का आकार 100 बाइट्स को पार कर जाता है तो टेपेस्ट्री प्रतिक्रिया को संकुचित कर देगा।

सुरक्षा

टेपेस्ट्री वेब एप्लिकेशन में ज्ञात सुरक्षा कमजोरियों के खिलाफ आवेदन को सुरक्षित करने के लिए कई विकल्प प्रदान करता है। इनमें से कुछ विकल्प नीचे सूचीबद्ध हैं -

  • HTTPS - टेपेस्ट्री पेज के साथ एनोटेट किया जा सकता है @Secure इसे एक सुरक्षित पृष्ठ बनाने के लिए और इसके द्वारा पहुँचा जा सकता है https protocol केवल।

  • Page access control - पृष्ठ को नियंत्रित करना केवल एक निश्चित उपयोगकर्ता द्वारा पहुँचा जा सकता है।

  • White-Listed Page - टेपेस्ट्री पृष्ठों को एनोटेट किया जा सकता है @WhitelistAccessOnly केवल के माध्यम से इसे सुलभ बनाने के लिए localhost

  • Asset Security- टेपेस्ट्री के तहत, केवल कुछ प्रकार की फाइलें ही सुलभ हैं। दूसरों को तभी पहुँचा जा सकता है जबMD5 hash फ़ाइल प्रदान की गई है।

  • Serialized Object Date - टेपेस्ट्री एक एचएमएसी को क्रमबद्ध जावा ऑब्जेक्ट डेटा में एकीकृत करता है और क्लाइंट को संदेश छेड़छाड़ से बचने के लिए भेजता है।

  • Cross Site Request Forgery- टेपेस्ट्री किसी भी सीएसआरएफ हमलों को रोकने के लिए टेपेस्ट्री-सीएसआरएफ-सुरक्षा नामक एक 3 आरडी पार्टी मॉड्यूल प्रदान करता है ।

  • Security Framework integration- टेपेस्ट्री एक प्रमाणीकरण / प्राधिकरण कार्यान्वयन में लॉक नहीं होती है। टेपेस्ट्री को किसी भी लोकप्रिय प्रमाणीकरण ढांचे के साथ एकीकृत किया जा सकता है।

लॉगिंग

टेपेस्ट्री लॉगिंग के लिए व्यापक समर्थन प्रदान करता है, एप्लिकेशन की प्रगति की स्वचालित रिकॉर्डिंग जैसे ही यह चलता है। टेपेस्ट्री डी-फैक्टो जावा लॉगिंग लाइब्रेरी का उपयोग करता है,SLF4J। एनोटेशन@Logविधि के प्रवेश और निकास और संभव अपवाद के रूप में अच्छी तरह से बाहर निकलने के लिए किसी भी घटक विधि में हो सकता है। इसके अलावा, टेपेस्ट्री प्रदान लकड़हारा वस्तु किसी भी घटक का उपयोग करके इंजेक्ट किया जा सकता है@Inject नीचे दिखाए अनुसार एनोटेशन -

public class MyPage { 
   @Inject 
   private Logger logger; 
   
   // . . . 
    
   void onSuccessFromForm() { 
      logger.info("Changes saved successfully"); 
   } 
     
   @Log 
   void onValidateFromForm() { 
      // logic 
   } 
}

अंत में, अब हम कह सकते हैं कि अपाचे टेपेस्ट्री संक्षिप्त, मापनीय, रखरखाव योग्य, मजबूत और अजाक्स-सक्षम अनुप्रयोगों के निर्माण के लिए सर्वोत्तम तरीके लाता है। टेपेस्ट्री को किसी भी तृतीय-पक्ष जावा एप्लिकेशन के साथ एकीकृत किया जा सकता है। यह एक बड़े वेब एप्लिकेशन को बनाने में भी मदद कर सकता है क्योंकि यह काफी आसान और तेज है।