अपाचे टेपेस्ट्री - उन्नत सुविधाएँ

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

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

टेपेस्ट्री में निर्मित लाइब्रेरी ऑफ कंट्रोल लाइब्रेरी है। टेपेस्ट्री IoC में गहराई से एकीकृत है और अपनी सभी विशेषताओं के लिए IoC का उपयोग करता है। टेपेस्ट्री 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 
   } 
}

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