स्ट्रट्स 2 - कॉन्फ़िगरेशन फ़ाइलें

यह अध्याय आपको मूल विन्यास के माध्यम से ले जाएगा जो कि एक के लिए आवश्यक है Struts 2आवेदन। यहां हम देखेंगे कि कुछ महत्वपूर्ण कॉन्फ़िगरेशन फ़ाइलों की मदद से क्या कॉन्फ़िगर किया जा सकता हैweb.xml, struts.xml, strutsconfig.xml तथा struts.properties

ईमानदारी से बोलना, आप केवल उपयोग करके काम शुरू कर सकते हैं web.xml तथा struts.xmlकॉन्फ़िगरेशन फ़ाइलें (जैसा कि आप पहले से ही हमारे पिछले अध्याय में देख चुके हैं, जहां हमारे उदाहरण ने इन दो फ़ाइलों का उपयोग करके काम किया है)। हालाँकि, आपके ज्ञान के लिए हम अन्य फ़ाइलों के बारे में भी बताएंगे।

Web.xml फ़ाइल

Web.xml कॉन्फ़िगरेशन फ़ाइल J2EE कॉन्फ़िगरेशन फ़ाइल है जो यह निर्धारित करती है कि HTTP अनुरोध के तत्व सर्वलेट कंटेनर द्वारा कैसे संसाधित किए जाते हैं। यह सख्ती से स्ट्रट्स 2 कॉन्फ़िगरेशन फ़ाइल नहीं है, लेकिन यह एक ऐसी फ़ाइल है जिसे काम करने के लिए स्ट्रट्स 2 के लिए कॉन्फ़िगर करने की आवश्यकता है।

जैसा कि पहले चर्चा की गई है, यह फ़ाइल किसी भी वेब एप्लिकेशन के लिए एक प्रवेश बिंदु प्रदान करती है। Struts2 अनुप्रयोग का प्रवेश बिंदु तैनाती डिस्क्रिप्टर (web.xml) में परिभाषित एक फिल्टर होगा। इसलिए हम web.xml में FilterDispatcher वर्ग की प्रविष्टि को परिभाषित करेंगे । Web.xml फ़ाइल को फ़ोल्डर के तहत बनाने की आवश्यकता हैWebContent/WEB-INF

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

निम्नलिखित web.xml फ़ाइल की सामग्री है जिसका उपयोग हमने अपने पिछले उदाहरण में किया था।

<?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_3_0.xsd"
   id = "WebApp_ID" version = "3.0">
   
   <display-name>Struts 2</display-name>
   <welcome-file-list>
      <welcome-file>index.jsp</welcome-file>
   </welcome-file-list>
   
   <filter>
      <filter-name>struts2</filter-name>
      <filter-class>
         org.apache.struts2.dispatcher.FilterDispatcher
      </filter-class>
   </filter>

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

</web-app>

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

Struts.xml फ़ाइल

struts.xmlफ़ाइल में कॉन्फ़िगरेशन जानकारी शामिल है जिसे आप क्रियाओं के विकसित होने के रूप में संशोधित करेंगे। इस फ़ाइल का उपयोग किसी एप्लिकेशन के लिए डिफ़ॉल्ट सेटिंग्स को ओवरराइड करने के लिए किया जा सकता है, उदाहरण के लिए struts.devMode = false और अन्य सेटिंग्स जो प्रॉपर्टी फ़ाइल में परिभाषित हैं। यह फ़ाइल फ़ोल्डर के तहत बनाई जा सकती हैWEB-INF/classes

हमें पिछले अध्याय में बताए गए हैलो वर्ल्ड उदाहरण में हमने struts.xml फ़ाइल पर एक नज़र डाली।

<?xml version = "1.0" Encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
   "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
   "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
   <constant name = "struts.devMode" value = "true" />
   <package name = "helloworld" extends = "struts-default">
     
      <action name = "hello" 
         class = "com.tutorialspoint.struts2.HelloWorldAction" 
         method = "execute">
         <result name = "success">/HelloWorld.jsp</result>
      </action>
      
      <-- more actions can be listed here -->

   </package>
   <-- more packages can be listed here -->

</struts>

ध्यान देने वाली पहली बात है DOCTYPE। सभी स्ट्रट्स कॉन्फ़िगरेशन फ़ाइल को सही सिद्धांत के रूप में हमारे छोटे उदाहरण में दिखाया गया है। <struts> रूट टैग तत्व है, जिसके तहत हम <पैकेज> टैग का उपयोग करके अलग-अलग पैकेज घोषित करते हैं। यहां <पैकेज> कॉन्फ़िगरेशन के पृथक्करण और संशोधन की अनुमति देता है। यह बहुत उपयोगी है जब आपके पास एक बड़ी परियोजना है और परियोजना अलग-अलग मॉड्यूल में विभाजित है।

उदाहरण के लिए, यदि आपकी परियोजना में तीन डोमेन हैं - business_application, customer_application और staff_application, तो आप तीन पैकेज बना सकते हैं और उचित पैकेज में संबद्ध क्रियाओं को संग्रहीत कर सकते हैं।

पैकेज टैग में निम्नलिखित विशेषताएं हैं -

अनु क्रमांक विशेषता और विवरण
1

name (required)

पैकेज के लिए विशिष्ट पहचानकर्ता

2

extends

यह पैकेज किस पैकेज से विस्तारित होता है? डिफ़ॉल्ट रूप से, हम बेस पैकेज के रूप में स्ट्रट्स-डिफॉल्ट का उपयोग करते हैं।

3

abstract

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

4

namespace

कार्यों के लिए अद्वितीय नाम स्थान

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

हम परिभाषित करते हैं action टैग हर उस URL से मेल खाते हैं जिसे हम एक्सेस करना चाहते हैं और हम एग्जीक्यूट () विधि के साथ एक क्लास को परिभाषित करते हैं जो तब तक एक्सेस किया जाएगा जब तक हम संबंधित URL तक पहुंच पाएंगे।

परिणाम निर्धारित करते हैं कि किसी कार्रवाई को निष्पादित करने के बाद ब्राउज़र में क्या वापस आता है। कार्रवाई से लौटी स्ट्रिंग एक परिणाम का नाम होना चाहिए। परिणाम प्रति क्रिया उपर्युक्त या "वैश्विक" परिणाम के रूप में कॉन्फ़िगर किए जाते हैं, जो पैकेज में प्रत्येक क्रिया के लिए उपलब्ध होते हैं। परिणाम वैकल्पिक हैname तथा typeजिम्मेदार बताते हैं। डिफ़ॉल्ट नाम मान "सफलता" है।

Struts.xml फ़ाइल समय के साथ बड़ी हो सकती है और इसलिए इसे पैकेजों द्वारा तोड़ना इसे संशोधित करने का एक तरीका है, लेकिन Strutsstruts.xml फ़ाइल को संशोधित करने का एक और तरीका प्रदान करता है। आप फ़ाइल को कई xml फ़ाइलों में विभाजित कर सकते हैं और उन्हें निम्न फैशन में आयात कर सकते हैं।

<?xml version = "1.0" Encoding = "UTF-8"?>
<!DOCTYPE struts PUBLIC
   "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
   "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>
   <include file="my-struts1.xml"/>
   <include file="my-struts2.xml"/>
</struts>

अन्य कॉन्फ़िगरेशन फ़ाइल जिसे हमने कवर नहीं किया है वह स्ट्रट्स- default.xml है। इस फ़ाइल में स्ट्रट्स के लिए मानक कॉन्फ़िगरेशन सेटिंग्स हैं और आपको अपनी 99.99% परियोजनाओं के लिए इन सेटिंग्स को नहीं छूना होगा। इस कारण से, हम इस फ़ाइल पर बहुत अधिक विवरण नहीं दे रहे हैं। आप रुचि रखते हैं, पर एक नज़र रखनाdefault.properties struts2-core-2.2.3.jar फ़ाइल में उपलब्ध फ़ाइल।

स्ट्रट्स-config.xml फ़ाइल

Struts-config.xml कॉन्फ़िगरेशन फ़ाइल वेब क्लाइंट में दृश्य और मॉडल घटकों के बीच एक लिंक है, लेकिन आपको अपनी परियोजनाओं के 99.99% के लिए इन सेटिंग्स को नहीं छूना होगा।

कॉन्फ़िगरेशन फ़ाइल में मुख्य रूप से निम्नलिखित तत्व शामिल हैं -

अनु क्रमांक इंटरसेप्टर और विवरण
1

struts-config

यह कॉन्फ़िगरेशन फ़ाइल का रूट नोड है।

2

form-beans

यह वह जगह है जहाँ आप अपने ActionForm उपवर्ग को एक नाम पर मैप करते हैं। आप इस नाम का उपयोग अपने एक्शनफ़ॉर्म के लिए स्ट्रेट्सकोनफिग.एक्सएमएल फ़ाइल के बाकी हिस्सों में, और यहां तक ​​कि अपने जेएसपी पृष्ठों पर भी कर सकते हैं।

3

global forwards

यह अनुभाग आपके वेब पेज पर एक नाम के लिए एक पेज मैप करता है। आप वास्तविक पृष्ठ को संदर्भित करने के लिए इस नाम का उपयोग कर सकते हैं। यह आपके वेब पृष्ठों पर हार्डकोडिंग URL से बचता है।

4

action-mappings

यह वह जगह है जहां आप फॉर्म हैंडलर घोषित करते हैं और उन्हें एक्शन मैपिंग के रूप में भी जाना जाता है।

5

controller

यह खंड स्ट्रेट्स इंटर्नल को कॉन्फ़िगर करता है और शायद ही कभी व्यावहारिक स्थितियों में उपयोग किया जाता है।

6

plug-in

यह खंड स्ट्रट्स को बताता है कि आपकी प्रॉपर्टीज़ फ़ाइलों को कहाँ ढूँढा जाए, जिसमें प्रॉम्प्ट और एरर मैसेज हों

निम्नलिखित नमूना struts-config.xml फ़ाइल है -

<?xml version = "1.0" Encoding = "ISO-8859-1" ?>
<!DOCTYPE struts-config PUBLIC
   "-//Apache Software Foundation//DTD Struts Configuration 1.0//EN"
   "http://jakarta.apache.org/struts/dtds/struts-config_1_0.dtd">

<struts-config>

   <!-- ========== Form Bean Definitions ============ -->
   <form-beans>
      <form-bean name = "login" type = "test.struts.LoginForm" />
   </form-beans>

   <!-- ========== Global Forward Definitions ========= -->
   <global-forwards>
   </global-forwards>

   <!-- ========== Action Mapping Definitions ======== -->
   <action-mappings>
      <action
         path = "/login"
         type = "test.struts.LoginAction" >

         <forward name = "valid" path = "/jsp/MainMenu.jsp" />
         <forward name = "invalid" path = "/jsp/LoginView.jsp" />
      </action>
   </action-mappings>

   <!-- ========== Controller Definitions ======== -->
   <controller contentType = "text/html;charset = UTF-8"
      debug = "3" maxFileSize = "1.618M" locale = "true" nocache = "true"/>

</struts-config>

Struts-config.xml फ़ाइल पर अधिक विवरण के लिए, कृपया अपने struts प्रलेखन की जाँच करें।

Struts.properties फ़ाइल

यह कॉन्फ़िगरेशन फ़ाइल फ्रेमवर्क के डिफ़ॉल्ट व्यवहार को बदलने के लिए एक तंत्र प्रदान करती है। दरअसल, सभी गुणों के भीतर निहित हैstruts.properties कॉन्फ़िगरेशन फ़ाइल में भी कॉन्फ़िगर किया जा सकता है web.xml का उपयोग करते हुए init-param, साथ ही में निरंतर टैग का उपयोग कर struts.xmlविन्यास फाइल। लेकिन, अगर आप चीजों को अलग और अधिक स्ट्रट्स को विशिष्ट रखना पसंद करते हैं, तो आप इस फाइल को फ़ोल्डर के तहत बना सकते हैंWEB-INF/classes

इस फ़ाइल में कॉन्फ़िगर किए गए मान कॉन्फ़िगर किए गए डिफ़ॉल्ट मानों को ओवरराइड करेंगे default.propertiesजो struts2-core-xyzjar वितरण में निहित है। गुणों का एक जोड़ा है कि आप का उपयोग कर बदलने पर विचार कर सकते हैंstruts.properties फ़ाइल -

### When set to true, Struts will act much more friendly for developers
struts.devMode = true

### Enables reloading of internationalization files
struts.i18n.reload = true

### Enables reloading of XML configuration files
struts.configuration.xml.reload = true

### Sets the port that the server is run on
struts.url.http.port = 8080

यहाँ किसी भी लाइन के साथ शुरू hash (#) एक टिप्पणी के रूप में माना जाएगा और इसे नजरअंदाज कर दिया जाएगा Struts 2