स्ट्रट्स 2 और टाइल्स इंटीग्रेशन

इस अध्याय में, हम स्ट्रट्स 2 के साथ टाइलों के ढांचे को एकीकृत करने में शामिल कदमों से गुजरते हैं। अपाचे टाइलें एक टेम्प्लेटिंग फ्रेमवर्क है जिसे वेब एप्लिकेशन यूजर इंटरफेस के विकास को सरल बनाने के लिए बनाया गया है।

सबसे पहले हमें अपाचे टाइल्स की वेबसाइट से टाइल्स जार फाइल डाउनलोड करने की आवश्यकता है । आपको प्रोजेक्ट की क्लास पथ पर निम्न जार फ़ाइलों को जोड़ने की आवश्यकता है।

  • tiles-api-x.y.z.jar
  • tiles-compat-x.y.z.jar
  • tiles-core-x.y.z.jar
  • tiles-jsp-x.y.z.jar
  • tiles-servlet-x.y.z.jar

उपरोक्त के अलावा, हमें आपके द्वारा struts2 डाउनलोड से निम्न जार फ़ाइलों को कॉपी करना होगा WEB-INF/lib

  • commons-beanutils-x.y.zjar
  • commons-digester-x.y.jar
  • struts2-tiles-plugin-x.y.z.jar

अब हम सेटअप करते हैं web.xmlस्ट्रट्स-टाइल्स एकीकरण के लिए नीचे दिए गए अनुसार। यहां ध्यान देने योग्य दो महत्वपूर्ण बिंदु हैं। सबसे पहले, हमें टाइल्स को बताने की जरूरत है, जहां टाइल कॉन्फ़िगरेशन फ़ाइल ढूंढनी हैtiles.xml। हमारे मामले में, यह अधीन होगा/WEB-INFफ़ोल्डर। इसके बाद हमें स्ट्रेट्स 2 डाउनलोड के साथ आने वाले टाइल्स श्रोता को इंट्रिलाइज करना होगा।

<?xml version = "1.0" Encoding = "UTF-8"?>
<web-app xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xmlns = "http://java.sun.com/xml/ns/javaee" 
   xmlns:web = "http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
   xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee 
   http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
   id = "WebApp_ID" version = "2.5">
   <display-name>Struts2Example15</display-name>
	
   <context-param>
      <param-name>
         org.apache.tiles.impl.BasicTilesContainer.DEFINITIONS_CONFIG
      </param-name>
      
      <param-value>
         /WEB-INF/tiles.xml
      </param-value>
   </context-param>

   <listener>
      <listener-class>
         org.apache.struts2.tiles.StrutsTilesListener
      </listener-class>
   </listener>

   <filter>
      <filter-name>struts2</filter-name>
      <filter-class>
         org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
      </filter-class>
   </filter>

   <filter-mapping>
      <filter-name>struts2</filter-name>
      <url-pattern>/*</url-pattern>
   </filter-mapping>

   <welcome-file-list>
      <welcome-file>index.jsp</welcome-file>
   </welcome-file-list>
</web-app>

अगला हम बनाते हैं tiles.xml निम्नलिखित सामग्री के साथ / वेब-इन्फो फ़ोल्डर के तहत -

<?xml version = "1.0" Encoding = "UTF-8" ?>

<!DOCTYPE tiles-definitions PUBLIC
   "-//Apache Software Foundation//DTD Tiles Configuration 2.0//EN"
   "http://tiles.apache.org/dtds/tiles-config_2_0.dtd">

<tiles-definitions>

   <definition name = "baseLayout" template="/baseLayout.jsp">
      <put-attribute name = "title"  value = "Template"/>
      <put-attribute name = "banner" value = "/banner.jsp"/>
      <put-attribute name = "menu"   value = "/menu.jsp"/>
      <put-attribute name = "body"   value = "/body.jsp"/>
      <put-attribute name = "footer"   value = "/footer.jsp"/>
   </definition>

   <definition name = "tiger" extends = "baseLayout">
      <put-attribute name = "title"  value = "Tiger"/>
      <put-attribute name = "body"   value = "/tiger.jsp"/>      
   </definition>

   <definition name = "lion" extends = "baseLayout">
      <put-attribute name = "title"  value = "Lion"/>
      <put-attribute name = "body"   value = "/lion.jsp"/>      
   </definition>
  
</tiles-definitions>

अगला, हम एक बुनियादी कंकाल लेआउट को परिभाषित करते हैं baseLayout.jsp। इसके पांच पुन: प्रयोज्य / अधिक उपयोग योग्य क्षेत्र हैं। यानीtitle, banner, menu, body तथा footer। हम बेसलैट के लिए डिफ़ॉल्ट मान प्रदान करते हैं और फिर हम दो कस्टमाइज़ेशन बनाते हैं जो डिफ़ॉल्ट लेआउट से विस्तारित होते हैं। बाघ लेआउट मूल लेआउट के समान है, सिवाय इसके कि यह उपयोग करता हैtiger.jspशीर्षक के रूप में इसके शरीर और पाठ "टाइगर" के रूप में। इसी तरह, सिंह लेआउट मूल लेआउट के समान है, सिवाय इसके कि यह बी का उपयोग करता हैlion.jsp शीर्षक के रूप में इसके शरीर और "शेर" के रूप में।

आइए हम व्यक्तिगत jsp फ़ाइलों पर एक नज़र डालें। निम्नलिखित की सामग्री हैbaseLayout.jsp फ़ाइल -

<%@ taglib uri = "http://tiles.apache.org/tags-tiles" prefix = "tiles"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
   "http://www.w3.org/TR/html4/loose.dtd">

<html>
   <head>
      <meta http-equiv="Content-Type" content="text/html; charset = UTF-8">
      <title>
         <tiles:insertAttribute name = "title" ignore="true" />
      </title>
   </head>

   <body>
      <tiles:insertAttribute name = "banner" /><br/>
      <hr/>
      <tiles:insertAttribute name = "menu" /><br/>
      <hr/>
      <tiles:insertAttribute name = "body" /><br/>
      <hr/>
      <tiles:insertAttribute name = "footer" /><br/>
   </body>
</html>

यहां, हम सिर्फ एक मूल HTML पृष्ठ को एक साथ रखते हैं जिसमें टाइल विशेषताएँ हैं। हम उन स्थानों पर टाइल की विशेषताओं को सम्मिलित करते हैं जहां हमें उनकी आवश्यकता होती है। इसके बाद, हम एक बनाते हैंbanner.jsp निम्नलिखित सामग्री के साथ फाइल करें -

<img src="http://www.tutorialspoint.com/images/tp-logo.gif"/>

menu.jsp फ़ाइल में निम्नलिखित पंक्तियाँ होंगी जो लिंक हैं - TigerMenu.action और LionMenu.action स्ट्रट्स क्रियाओं के लिए।

<%@taglib uri = "/struts-tags" prefix = "s"%>

<a href = "<s:url action = "tigerMenu"/>" Tiger</a><br>
<a href = "<s:url action = "lionMenu"/>" Lion</a><br>

lion.jsp फ़ाइल में निम्न सामग्री होगी -

<img src="http://upload.wikimedia.org/wikipedia/commons/d/d2/Lion.jpg"/>
The lion

tiger.jsp फ़ाइल में निम्न सामग्री होगी -

<img src="http://www.freewebs.com/tigerofdarts/tiger.jpg"/>
The tiger

इसके बाद, हम एक्शन क्लास फाइल बनाते हैं MenuAction.java जिसमें निम्नलिखित शामिल हैं -

package com.tutorialspoint.struts2;

import com.opensymphony.xwork2.ActionSupport;

public class MenuAction extends ActionSupport {
   public String tiger() { return "tiger"; }
   public String lion() { return "lion"; }
}

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

<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>
   <package name = "default" extends = "struts-default">
      <result-types>
         <result-type name = "tiles" 
         class="org.apache.struts2.views.tiles.TilesResult" />
      </result-types>

      <action name = "*Menu" method = "{1}" 
         class = "com.tutorialspoint.struts2.MenuAction">
         <result name = "tiger" type = "tiles">tiger</result>
         <result name = "lion" type = "tiles">lion</result>
      </action>

   </package>
</struts>

उपरोक्त फ़ाइल में हमने क्या किया है, इसकी जाँच करते हैं। सबसे पहले, हमने "टाइलें" नामक एक नया परिणाम प्रकार घोषित किया क्योंकि अब हम दृश्य तकनीक के लिए सादे जेपी के बजाय टाइल्स का उपयोग कर रहे हैं। Struts2 को टाइल दृश्य परिणाम प्रकार के लिए अपना समर्थन प्राप्त है, इसलिए हम "org.apache.struts2.view.tiles.TilesResult" वर्ग का परिणाम प्रकार "टाइल" बनाते हैं।

अगला, हम यह कहना चाहते हैं कि यदि अनुरोध /tigerMenu.action के लिए है तो उपयोगकर्ता को टाइगर टाइल पृष्ठ पर ले जाएं और यदि अनुरोध /lionMenu.action के लिए है तो उपयोगकर्ता को शेर टाइल्स पृष्ठ पर ले जाएं।

हम इसे नियमित अभिव्यक्ति का एक सा उपयोग करके प्राप्त करते हैं। हमारी क्रिया परिभाषा में, हम कुछ भी कहते हैं जो इस क्रिया द्वारा "" मेनू "पैटर्न से मेल खाता है। मेन्यूएशन क्लास में मिलान विधि लागू की जाएगी। यही है, tigerMenu.action बाघ का आह्वान करेगा () और lionMenu.action शेर का आह्वान करेगा ()। फिर हमें परिणाम के परिणामों को उपयुक्त टाइल्स पृष्ठों पर मैप करना होगा।

अब प्रोजेक्ट नाम पर राइट क्लिक करें और क्लिक करें Export > WAR Fileएक वार फाइल बनाने के लिए। फिर इस WAR को Tomcat की वेबऐप्स डायरेक्टरी में तैनात करें। अंत में, टॉमकैट सर्वर शुरू करें और URL तक पहुंचने का प्रयास करेंhttp://localhost:8080/HelloWorldStruts2/tigerMenu.jsp। यह निम्न स्क्रीन का उत्पादन करेगा -

इसी तरह, अगर आपको lionMenu.action पेज मिला है, तो आप शेर का पेज देखेंगे जो उसी टाइल लेआउट का उपयोग करता है।