चींटी त्वरित गाइड

ANT का अर्थ है एक और नीट टूल। यह अपाचे से जावा-आधारित बिल्ड टूल है। अपाचे चींटी के विवरण में जाने से पहले, हमें पहले यह समझना चाहिए कि हमें पहली जगह में एक बिल्ड टूल की आवश्यकता क्यों है।

एक बिल्ड टूल की आवश्यकता है

औसतन, एक डेवलपर निर्माण और तैनाती जैसे सांसारिक कार्यों को करने में काफी समय खर्च करता है, जिसमें शामिल हैं:

  • कोड संकलित करना
  • बायनेरिज़ की पैकेजिंग करें
  • परीक्षण सर्वर पर बायनेरिज़ की तैनाती
  • परिवर्तनों का परीक्षण
  • कोड को एक स्थान से दूसरे स्थान पर कॉपी करना

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

अपाचे चींटी का इतिहास

  • चींटी जेम्स डंकन डेविडसन (टॉमकैट के मूल लेखक) द्वारा बनाई गई थी।

  • यह मूल रूप से टॉमकैट के निर्माण के लिए इस्तेमाल किया गया था, और टॉमकैट वितरण के एक भाग के रूप में बंडल किया गया था।

  • चींटी अपाचे मेक टूल से जुड़ी समस्याओं और जटिलताओं से पैदा हुई थी।

  • चींटी को वर्ष 2000 में अपाचे में एक स्वतंत्र परियोजना के रूप में पदोन्नत किया गया था। मई 2014 को अपाचे चींटी का नवीनतम संस्करण 1.9.4 है।

अपाचे चींटी की विशेषताएं

  • चींटी सबसे पूर्ण जावा बिल्ड और परिनियोजन उपकरण उपलब्ध है।

  • चींटी प्लेटफ़ॉर्म न्यूट्रल है और फ़ाइल सेपरेटर जैसे प्लेटफ़ॉर्म विशिष्ट गुणों को संभाल सकती है।

  • चींटी का उपयोग प्लेटफ़ॉर्म विशिष्ट कार्यों को करने के लिए किया जा सकता है जैसे कि 'टच' कमांड का उपयोग करके फ़ाइल के संशोधित समय को संशोधित करना।

  • चींटी स्क्रिप्ट सादे XML का उपयोग करके लिखी जाती है। यदि आप पहले से ही XML से परिचित हैं, तो आप चींटी को बहुत जल्दी सीख सकते हैं।

  • चींटी जटिल दोहराव वाले कार्यों को स्वचालित करने में अच्छी है।

  • चींटी पूर्वनिर्धारित कार्यों की एक बड़ी सूची के साथ आती है।

  • चींटी कस्टम कार्यों को विकसित करने के लिए एक इंटरफ़ेस प्रदान करती है।

  • चींटी को कमांड लाइन से आसानी से मंगवाया जा सकता है और यह मुफ्त और वाणिज्यिक आईडीई के साथ एकीकृत कर सकती है।

अपाचे चींटी चींटी को अपाचे सॉफ्टवेयर लाइसेंस के तहत वितरित किया जाता है, जो पूर्णतया खुला स्रोत लाइसेंस है जो ओपन सोर्स पहल द्वारा प्रमाणित है।

नवीनतम अपाचे चींटी संस्करण, जिसमें इसका पूर्ण-स्रोत कोड, क्लास फाइलें और प्रलेखन शामिल हैं, पर पाया जा सकता है http://ant.apache.org.

अपाचे चींटी को स्थापित करना

यह माना जाता है कि आपने अपने कंप्यूटर पर जावा डेवलपमेंट किट (JDK) पहले ही डाउनलोड और इंस्टॉल कर लिया है। यदि नहीं, तो कृपया यहां दिए गए निर्देशों का पालन करें ।

  • सुनिश्चित करें कि JAVA_HOME पर्यावरण चर उस फ़ोल्डर पर सेट है जहाँ आपका JDK स्थापित है।

  • से बायनेरिज़ डाउनलोड करें http://ant.apache.org

  • ज़िप फ़ाइल को सुविधाजनक स्थान c: \ folder में अनज़िप करें। Winzip, winRAR, 7-zip या इसी तरह के औजारों का उपयोग करना।

  • नामक एक नया वातावरण चर बनाएँ ANT_HOME इस मामले में चींटी स्थापना फ़ोल्डर को इंगित करता है c:\apache-ant-1.8.2-bin फ़ोल्डर।

  • पथ चींटी पर्यावरण चर के लिए अपाचे चींटी बैच फ़ाइल में पथ को जोड़ें। हमारे मामले में यह होगाc:\apache-ant-1.8.2-bin\bin फ़ोल्डर।

अपाचे चींटी स्थापना का सत्यापन

अपने कंप्यूटर पर अपाचे चींटी की सफल स्थापना को सत्यापित करने के लिए, अपने कमांड प्रॉम्प्ट पर चींटी टाइप करें।

आपको इसके समान आउटपुट देखना चाहिए:

C:\>ant -version
Apache Ant(TM) version 1.8.2 compiled on December 20 2010

यदि आप उपरोक्त आउटपुट नहीं देखते हैं, तो कृपया पुष्टि करें कि आपने स्थापना चरणों का ठीक से पालन किया है।

ग्रहण लगाना

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

ग्रहण स्थापित करने के लिए:

  • Www.eclipse.org से नवीनतम ग्रहण बायनेरिज़ डाउनलोड करें

  • ग्रहण बायनेरिज़ को सुविधाजनक स्थान पर अनज़िप करें, c: \ folder

  • C: \ eclipse \ eclipse.exe से ग्रहण को चलाएँ

आमतौर पर, चींटी की बिल्ड फ़ाइल, कहा जाता है build.xmlपरियोजना के आधार निर्देशिका में निवास करना चाहिए। हालाँकि फ़ाइल नाम या उसके स्थान पर कोई प्रतिबंध नहीं है। आप अन्य फ़ाइल नामों का उपयोग करने या किसी अन्य स्थान पर बिल्ड फ़ाइल सहेजने के लिए स्वतंत्र हैं।

इस अभ्यास के लिए, अपने कंप्यूटर में कहीं भी बिल्ड.xml नामक एक फ़ाइल बनाएँ जिसमें निम्न सामग्री हो:

<?xml version="1.0"?>
   <project name="Hello World Project" default="info">
   <target name="info">
      <echo>Hello World - Welcome to Apache Ant!</echo>
   </target>
</project>

ध्यान दें कि xml घोषणा से पहले कोई रिक्त लाइन (ओं) या व्हाट्सएप नहीं होना चाहिए। यदि आप उन्हें अनुमति देते हैं, तो चींटी बिल्ड को निष्पादित करते समय निम्न त्रुटि संदेश आता है -

प्रसंस्करण निर्देश लक्ष्य "[xX] [mM] [lL]" से मेल खाने की अनुमति नहीं है। सभी बिल्ड फ़ाइलों के लिए आवश्यक हैproject तत्व और कम से कम एक target तत्व।

XML तत्व project तीन विशेषताएं हैं:

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

लक्ष्य उन कार्यों का एक संग्रह है जिन्हें आप एक इकाई के रूप में चलाना चाहते हैं। हमारे उदाहरण में, हमारे पास उपयोगकर्ता को सूचनात्मक संदेश प्रदान करने के लिए एक सरल लक्ष्य है।

लक्ष्य अन्य लक्ष्यों पर निर्भरता हो सकते हैं। उदाहरण के लिए, एdeploy लक्ष्य पर निर्भरता हो सकती है package लक्ष्य, package लक्ष्य पर निर्भरता हो सकती है compileलक्ष्य और आगे। निर्भरताएँ का उपयोग करके निरूपित की जाती हैंdependsविशेषता। उदाहरण के लिए:

<target name="deploy" depends="package">
  ....
</target>
<target name="package" depends="clean,compile">
  ....
</target>
<target name="clean" >
  ....
</target>
<target name="compile" >
  ....
</target>

लक्ष्य तत्व में निम्नलिखित विशेषताएं हैं:

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

echoउपर्युक्त उदाहरण में कार्य एक तुच्छ कार्य है जो एक संदेश प्रिंट करता है। हमारे उदाहरण में, यह हैलो वर्ल्ड के संदेश को प्रिंट करता है ।

चींटी बिल्ड फ़ाइल को चलाने के लिए, कमांड प्रॉम्प्ट खोलें और उस फ़ोल्डर में नेविगेट करें जहां build.xml रहता है, और टाइप करें ant info। आप भी टाइप कर सकते हैंantबजाय। दोनों काम करेंगे, क्योंकिinfoबिल्ड फ़ाइल में डिफ़ॉल्ट लक्ष्य है। आपको निम्न आउटपुट देखना चाहिए:

C:\>ant
Buildfile: C:\build.xml

info: [echo] Hello World - Welcome to Apache Ant!

BUILD SUCCESSFUL
Total time: 0 seconds

C:\>

एंट बिल्ड फ़ाइलों को XML में लिखा जाता है, जो आपकी पसंदीदा प्रोग्रामिंग भाषा में वैरिएबल घोषित करने की अनुमति नहीं देता है। हालाँकि, जैसा कि आपने कल्पना की होगी, यह उपयोगी होगा यदि चींटी ने प्रोजेक्ट नाम, प्रोजेक्ट स्रोत निर्देशिका आदि जैसे चर घोषित किए।

चींटी उपयोग करती है propertyतत्व जो आपको गुण निर्दिष्ट करने की अनुमति देता है। यह गुणों को एक निर्माण से दूसरे में या एक पर्यावरण से दूसरे में परिवर्तित करने की अनुमति देता है।

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

गुण विवरण
ant.file बिल्ड फ़ाइल का पूरा स्थान।
ant.version अपाचे चींटी स्थापना का संस्करण।
basedir के रूप में निर्दिष्ट, निर्माण के आधार basedir की विशेषता project तत्व।
ant.java.version JDK का संस्करण जो चींटी द्वारा उपयोग किया जाता है।
ant.project.name में निर्दिष्ट परियोजना का नाम name की श्रद्धांजलि project तत्व।
ant.project.default लक्ष्य वर्तमान परियोजना का डिफ़ॉल्ट लक्ष्य।
ant.project.invoked-लक्ष्य कोमा ने उन लक्ष्यों की सूची को अलग कर दिया जो वर्तमान परियोजना में लगाए गए थे।
ant.core.lib चींटी जार फ़ाइल का पूरा स्थान।
ant.home चींटी स्थापना का घर निर्देशिका।
ant.library.dir चींटी लाइब्रेरी फ़ाइलों के लिए होम निर्देशिका - आमतौर पर ANT_HOME / lib फ़ोल्डर।

चींटी भी सिस्टम गुण (उदाहरण: file.separator) बिल्ड फ़ाइल के लिए उपलब्ध कराता है।

उपरोक्त के अतिरिक्त, उपयोगकर्ता अतिरिक्त गुणों को परिभाषित कर सकता है propertyतत्व। निम्नलिखित उदाहरण से पता चलता है कि एक संपत्ति को कैसे परिभाषित किया जाएsitename:

<?xml version="1.0"?>
<project name="Hello World Project" default="info">
   <property name="sitename" value="www.tutorialspoint.com"/>
   <target name="info">
      <echo>Apache Ant version is ${ant.version} - You are 
         at ${sitename} </echo>
   </target>
</project>

उपरोक्त बिल्ड फ़ाइल पर चींटी चलाना निम्नलिखित आउटपुट उत्पन्न करता है:

C:\>ant
Buildfile: C:\build.xml

info: [echo] Apache Ant version is Apache Ant(TM) version 1.8.2  
      compiled on December 20 2010 - You are at www.tutorialspoint.com

BUILD SUCCESSFUL
Total time: 0 seconds
C:\>

बिल्ड फ़ाइल में सीधे गुण सेट करना ठीक है, यदि आप मुट्ठी भर गुणों के साथ काम कर रहे हैं। हालांकि, एक बड़ी परियोजना के लिए, यह एक अलग संपत्ति फ़ाइल में गुणों को संग्रहीत करने के लिए समझ में आता है।

एक अलग फ़ाइल में गुणों को संग्रहीत करना निम्नलिखित लाभ प्रदान करता है:

  • यह आपको एक ही बिल्ड फ़ाइल का पुन: उपयोग करने की अनुमति देता है, विभिन्न निष्पादन वातावरण के लिए अलग-अलग संपत्ति सेटिंग्स के साथ। उदाहरण के लिए, बिल्ड गुण फ़ाइल को अलग से DEV, TEST और PROD वातावरण के लिए बनाए रखा जा सकता है।

  • यह उपयोगी है जब आप किसी संपत्ति (किसी विशेष वातावरण में) के सामने के मूल्यों को नहीं जानते हैं। यह आपको बिल्ड को अन्य वातावरणों में प्रदर्शन करने की अनुमति देता है जहां संपत्ति मूल्य ज्ञात है।

कोई कठिन और तेज़ नियम नहीं है, लेकिन आम तौर पर संपत्ति फ़ाइल का नाम है build.properties और साथ-साथ रखा गया है build.xmlफ़ाइल। आप परिनियोजन वातावरण के आधार पर कई बिल्ड गुण फ़ाइलें बना सकते हैं - जैसेbuild.properties.dev तथा build.properties.test.

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

निम्नलिखित उदाहरण एक दिखाता है build.xml फ़ाइल और उससे संबंधित build.properties फ़ाइल:

build.xml

<?xml version="1.0"?>
<project name="Hello World Project" default="info">
   <property file="build.properties"/>
      <target name="info">
         <echo>Apache Ant version is ${ant.version} - You are 
            at ${sitename} </echo>
      </target>
</project>

build.properties

# The Site Name
sitename=www.tutorialspoint.com
buildversion=3.3.2

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

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

गुण विवरण
ant.file बिल्ड फ़ाइल का पूरा स्थान।
ant.version अपाचे चींटी स्थापना का संस्करण।
basedir के रूप में निर्दिष्ट, निर्माण के आधार basedir की विशेषता project तत्व।
ant.java.version JDK का संस्करण जो चींटी द्वारा उपयोग किया जाता है।
ant.project.name में निर्दिष्ट परियोजना का नाम name की श्रद्धांजलि project तत्व।
ant.project.default लक्ष्य वर्तमान परियोजना का डिफ़ॉल्ट लक्ष्य।
ant.project.invoked-लक्ष्य कोमा ने उन लक्ष्यों की सूची को अलग कर दिया जो वर्तमान परियोजना में लगाए गए थे।
ant.core.lib चींटी जार फ़ाइल का पूरा स्थान।
ant.home चींटी स्थापना का घर निर्देशिका।
ant.library.dir चींटी लाइब्रेरी फ़ाइलों के लिए होम निर्देशिका - आमतौर पर ANT_HOME / lib फ़ोल्डर।

इस अध्याय में प्रस्तुत उदाहरण का उपयोग करता है ant.version निर्मित संपत्ति।

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

निम्नलिखित डेटा प्रकार अपाचे चींटी द्वारा प्रदान किए गए हैं।

फ़ाइलसेट

फ़ाइलसेट डेटा प्रकार फ़ाइलों के संग्रह का प्रतिनिधित्व करता है। यह एक विशेष पैटर्न से मेल खाने वाली फ़ाइलों को शामिल करने या बाहर करने के लिए एक फिल्टर के रूप में उपयोग किया जाता है।

उदाहरण के लिए, निम्न कोड देखें। यहाँ, src विशेषता प्रोजेक्ट के स्रोत फ़ोल्डर की ओर इशारा करती है।

फ़ाइलसेट स्रोत फ़ोल्डर में सभी .java फ़ाइलों का चयन करता है, सिवाय उनके जिसमें 'स्टब' शब्द होता है। केस-संवेदी फ़िल्टर को फाइलसेट पर लागू किया जाता है जिसका अर्थ है Samplestub.java नाम वाली फाइल को फाइलसेट से बाहर नहीं किया जाएगा।

<fileset dir="${src}" casesensitive="yes">
   <include name="**/*.java"/>
   <exclude name="**/*Stub*"/>
</fileset>

पैटर्न सेट

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

  • ? - एक वर्ण से मेल खाता है।

  • * - शून्य या कई वर्णों से मेल खाता है।

  • ** - शून्य या कई निर्देशिकाओं का पुनरावर्ती मेल खाता है।

निम्न उदाहरण में एक पैटर्न सेट के उपयोग को दर्शाया गया है।

<patternset id="java.files.without.stubs">
   <include name="src/**/*.java"/>
   <exclude name="src/**/*Stub*"/>
</patternset>

पैटर्नसेट को फिर से फाइलसेट के साथ पुन: उपयोग किया जा सकता है:

<fileset dir="${src}" casesensitive="yes">
   <patternset refid="java.files.without.stubs"/>
</fileset>

फ़ाइल सूची

फाइललिस्ट डेटा प्रकार निम्नलिखित अंतरों को छोड़कर फाइल सेट के समान है:

  • फाइललिस्ट में स्पष्ट रूप से फाइलों की सूचियां होती हैं और यह वाइल्ड कार्ड का समर्थन नहीं करता है।

  • फाइललिस्ट डेटा प्रकार मौजूदा या गैर-मौजूदा फ़ाइलों के लिए लागू किया जा सकता है।

आइए हम फ़ाइनलिस्ट डेटा प्रकार का निम्नलिखित उदाहरण देखें। यहाँ, विशेषताwebapp.src.folder परियोजना के वेब एप्लिकेशन स्रोत फ़ोल्डर के अंक।

<filelist id="config.files" dir="${webapp.src.folder}">
   <file name="applicationConfig.xml"/>
   <file name="faces-config.xml"/>
   <file name="web.xml"/>
   <file name="portlet.xml"/>
</filelist>

फ़िल्टर सेट

कॉपी कार्य के साथ-साथ एक फ़िल्टर डेटा प्रकार का उपयोग करके, आप सभी फ़ाइलों में कुछ पाठ को प्रतिस्थापित कर सकते हैं जो प्रतिस्थापन मूल्य के साथ पैटर्न से मेल खाते हैं।

एक सामान्य उदाहरण संस्करण संख्या को रिलीज़ नोट्स फ़ाइल में जोड़ना है, जैसा कि निम्नलिखित कोड में दिखाया गया है।

<copy todir="${output.dir}">
   <fileset dir="${releasenotes.dir}" includes="**/*.txt"/>
   <filterset>
      <filter token="VERSION" value="${current.version}"/>
   </filterset>
</copy>

इस कोड में:

  • विशेषता है output.dir परियोजना के आउटपुट फ़ोल्डर को इंगित करता है।

  • विशेषता है releasenotes.dir परियोजना के रिलीज नोट्स फ़ोल्डर के लिए अंक।

  • विशेषता है current.version परियोजना के वर्तमान संस्करण फ़ोल्डर को इंगित करता है।

  • प्रतिलिपि कार्य, जैसा कि नाम से पता चलता है, का उपयोग फ़ाइलों को एक स्थान से दूसरे स्थान पर कॉपी करने के लिए किया जाता है।

पथ

pathडेटा प्रकार आमतौर पर एक वर्ग-पथ का प्रतिनिधित्व करने के लिए उपयोग किया जाता है। पथ में प्रवेश अर्धविराम या कॉलोन का उपयोग करके अलग किया जाता है। हालाँकि, इन वर्णों को निष्पादन प्रणाली के पथ विभाजक वर्ण द्वारा रन-टाइम पर प्रतिस्थापित किया जाता है।

क्लासपाथ परियोजना में जार फ़ाइलों और कक्षाओं की सूची पर सेट है, जैसा कि नीचे दिए गए उदाहरण में दिखाया गया है।

<path id="build.classpath.jar">
   <pathelement path="${env.J2EE_HOME}/${j2ee.jar}"/>
   <fileset dir="lib">
      <include name="**/*.jar"/>
   </fileset>
</path>

इस कोड में:

  • विशेषता है env.J2EE_HOME पर्यावरण चर के अंक J2EE_HOME

  • विशेषता है j2ee.jar J2EE बेस फ़ाइल में J2EE जार फ़ाइल के नाम को इंगित करता है।

अब जब हमने चींटी के डेटा प्रकारों के बारे में जान लिया है, तो उस ज्ञान को कार्य में लगाने का समय आ गया है। हम इस अध्याय में एक परियोजना बनाएंगे। इस अध्याय का उद्देश्य एक एंट फ़ाइल का निर्माण करना है जो जावा कक्षाओं को संकलित करता है और उन्हें WEB-INF \ classes फ़ोल्डर में रखता है।

निम्नलिखित प्रोजेक्ट संरचना पर विचार करें:

  • डेटाबेस स्क्रिप्ट में संग्रहीत हैं db फ़ोल्डर।

  • जावा स्रोत कोड में संग्रहीत है src फ़ोल्डर।

  • चित्र, js, META-INF, शैलियाँ (css) में संग्रहीत हैं war फ़ोल्डर।

  • JSP में संग्रहीत हैं jsp फ़ोल्डर।

  • तृतीय पक्ष जार फ़ाइलों में संग्रहीत हैं lib फ़ोल्डर।

  • जावा क्लास की फाइलों को स्टोर किया जाता है WEB-INF\classes फ़ोल्डर।

यह प्रोजेक्ट बनाता है Hello World बाकी ट्यूटोरियल के लिए फैक्स एप्लिकेशन।

C:\work\FaxWebApplication>tree
Folder PATH listing
Volume serial number is 00740061 EC1C:ADB1
C:.
+---db
+---src
.  +---faxapp
.  +---dao
.  +---entity
.  +---util
.  +---web
+---war
   +---images
   +---js
   +---META-INF
   +---styles
   +---WEB-INF
      +---classes
      +---jsp
      +---lib

यहाँ इस परियोजना के लिए build.xml आवश्यक है। आइए हम इसे टुकड़ा द्वारा टुकड़ा मानते हैं।

<?xml version="1.0"?>
<project name="fax" basedir="." default="build">
   <property name="src.dir" value="src"/>
   <property name="web.dir" value="war"/>
   <property name="build.dir" value="${web.dir}/WEB-INF/classes"/>
   <property name="name" value="fax"/>

   <path id="master-classpath">
      <fileset dir="${web.dir}/WEB-INF/lib">
         <include name="*.jar"/>
      </fileset>
      <pathelement path="${build.dir}"/>
   </path>

   <target name="build" description="Compile source tree java files">
      <mkdir dir="${build.dir}"/>
      <javac destdir="${build.dir}" source="1.5" target="1.5">
         <src path="${src.dir}"/>
         <classpath refid="master-classpath"/>
      </javac>
   </target>
 
   <target name="clean" description="Clean output directories">
      <delete>
         <fileset dir="${build.dir}">
            <include name="**/*.class"/>
         </fileset>
      </delete>
   </target>
</project>

सबसे पहले, हमें स्रोत, वेब और बिल्ड फ़ोल्डर्स के लिए कुछ गुणों की घोषणा करें।

<property name="src.dir" value="src"/>
<property name="web.dir" value="war"/>
<property name="build.dir" value="${web.dir}/WEB-INF/classes"/>

इस उदाहरण में:

  • src.dir प्रोजेक्ट के स्रोत फ़ोल्डर को संदर्भित करता है जहां जावा स्रोत फ़ाइलें मिल सकती हैं।

  • web.dir परियोजना के वेब स्रोत फ़ोल्डर को संदर्भित करता है, जहां आप JSP, web.xml, css, javascript और अन्य वेब संबंधित फाइलें पा सकते हैं

  • build.dir प्रोजेक्ट संकलन के आउटपुट फ़ोल्डर को संदर्भित करता है।

गुण अन्य गुणों का उल्लेख कर सकते हैं। जैसा कि उपरोक्त उदाहरण में दिखाया गया है,build.dir संपत्ति के लिए एक संदर्भ बनाता है web.dir संपत्ति।

इस उदाहरण में, src.dir प्रोजेक्ट के स्रोत फ़ोल्डर को संदर्भित करता है।

हमारी परियोजना का डिफ़ॉल्ट लक्ष्य है compileलक्ष्य। लेकिन पहले हम पर नजर डालते हैंclean लक्ष्य।

स्वच्छ लक्ष्य, जैसा कि नाम से पता चलता है, बिल्ड फ़ोल्डर में फ़ाइलों को हटा देता है।

<target name="clean" description="Clean output directories">
   <delete>
      <fileset dir="${build.dir}">
         <include name="**/*.class"/>
      </fileset>
   </delete>
</target>

मास्टर-क्लासपाथ के पास क्लासपैथ की जानकारी है। इस स्थिति में, यह बिल्ड फ़ोल्डर में कक्षाएं और lib फ़ोल्डर में जार फ़ाइलें शामिल करता है।

<path id="master-classpath">
   <fileset dir="${web.dir}/WEB-INF/lib">
      <include name="*.jar"/>
   </fileset>
   <pathelement path="${build.dir}"/>
</path>

अंत में, फ़ाइलों का निर्माण करने के लिए निर्माण लक्ष्य। सबसे पहले, हम बिल्ड डायरेक्टरी बनाते हैं, अगर यह मौजूद नहीं है। तब हम javac कमांड निष्पादित करते हैं (हमारे लक्ष्य संकलन के रूप में jdk1.5 निर्दिष्ट करते हुए)। हम javac कार्य के लिए स्रोत फ़ोल्डर और classpath की आपूर्ति करते हैं और इसे बिल्ड फ़ोल्डर में वर्ग फ़ाइलों को छोड़ने के लिए कहते हैं।

<target name="build" description="Compile main source tree java files">
   <mkdir dir="${build.dir}"/>
   <javac destdir="${build.dir}" source="1.5" target="1.5" debug="true"
      deprecation="false" optimize="false" failonerror="true">
      <src path="${src.dir}"/>
      <classpath refid="master-classpath"/>
   </javac>
</target>

इस फाइल पर चींटी का निष्पादन जावा स्रोत फ़ाइलों को संकलित करता है और कक्षाओं को बिल्ड फ़ोल्डर में रखता है।

निम्नलिखित परिणाम चींटी फ़ाइल को चलाने का परिणाम है:

C:\>ant
Buildfile: C:\build.xml

BUILD SUCCESSFUL
Total time: 6.3 seconds

फ़ाइलों को संकलित और में रखा गया है build.dir फ़ोल्डर।

प्रलेखन किसी भी परियोजना में एक होना चाहिए। एक परियोजना के रखरखाव में प्रलेखन एक महान भूमिका निभाता है। जावा इन-बिल्ट के उपयोग से प्रलेखन को आसान बनाता हैjavadocउपकरण। चींटी मांग पर प्रलेखन उत्पन्न करके इसे और भी आसान बनाती है।

जैसा कि आप जानते हैं, javadoc टूल अत्यधिक लचीला है और कई कॉन्फ़िगरेशन विकल्पों की अनुमति देता है। चींटी इन विन्यास विकल्पों को जावदोक कार्य के माध्यम से उजागर करती है। यदि आप javadocs से अपरिचित हैं, तो हम सुझाव देते हैं कि आप इस जावा प्रलेखन ट्यूटोरियल से शुरुआत करें ।

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

गुण

स्रोत का उपयोग करके निर्दिष्ट किया जा सकता है sourcepath, sourcepathref या sourcefiles

  • sourcepath स्रोत फ़ाइलों के फ़ोल्डर (जैसे src फ़ोल्डर) को इंगित करने के लिए उपयोग किया जाता है।

  • sourcepathref एक पथ का उल्लेख करने के लिए उपयोग किया जाता है जो पथ विशेषता (उदाहरण के लिए, प्रतिनिधियों) src.dir) द्वारा संदर्भित है।

  • sourcefiles का उपयोग तब किया जाता है जब आप अलग-अलग फ़ाइलों को अल्पविराम से अलग की गई सूची के रूप में निर्दिष्ट करना चाहते हैं।

गंतव्य पथ का उपयोग करके निर्दिष्ट किया गया है destdir फ़ोल्डर (जैसे build.dir)।

आप फ़िल्टर कर सकते हैं javadocपैकेज के नामों को निर्दिष्ट करके कार्य को शामिल किया जाना है। यह का उपयोग करके हासिल किया हैpackagenames विशेषता, पैकेज फ़ाइलों की अल्पविराम से अलग की गई सूची।

आप केवल सार्वजनिक, निजी, पैकेज, या संरक्षित कक्षाओं और सदस्यों को दिखाने के लिए javadoc प्रक्रिया को फ़िल्टर कर सकते हैं। यह का उपयोग करके हासिल किया हैprivate, public, package तथा protected जिम्मेदार बताते हैं।

आप संबंधित विशेषताओं का उपयोग करके लेखक और संस्करण जानकारी को शामिल करने के लिए javadoc कार्य भी बता सकते हैं।

आप संकुल को एक साथ प्रयोग करके समूह बना सकते हैं group विशेषता, ताकि नेविगेट करना आसान हो जाए।

यह सब एक साथ डालें

आइए हम अपने विषय को जारी रखें Hello worldफैक्स आवेदन। हमें अपने फ़ैक्स एप्लिकेशन प्रोजेक्ट में एक दस्तावेज़ लक्ष्य जोड़ें।

नीचे दिए गए एक उदाहरण javadoc कार्य हमारी परियोजना में उपयोग किया जाता है। इस उदाहरण में, हमने javadoc का उपयोग करने के लिए निर्दिष्ट किया हैsrc.dir स्रोत निर्देशिका के रूप में, और doc लक्ष्य के रूप में।

हमने java प्रलेखन पृष्ठों पर दिखाई देने वाली विंडो शीर्षक, शीर्ष लेख और पाद लेख जानकारी को भी अनुकूलित किया है।

इसके अलावा, हमने तीन समूह बनाए हैं:

  • हमारे स्रोत फ़ोल्डर में उपयोगिता वर्गों के लिए एक,
  • उपयोगकर्ता इंटरफ़ेस वर्गों के लिए एक, और
  • डेटाबेस से संबंधित वर्गों के लिए एक।

आप देख सकते हैं कि डेटा पैकेज समूह में दो पैकेज हैं-फैक्सएप.इनटाइटी और फैक्सएप्पडाउ।

<target name="generate-javadoc">
   <javadoc packagenames="faxapp.*" sourcepath="${src.dir}" 
      destdir="doc" version="true" windowtitle="Fax Application">
      <doctitle><![CDATA[= Fax Application =]]></doctitle>
      <bottom>
         <![CDATA[Copyright © 2011. All Rights Reserved.]]>
      </bottom>
      <group title="util packages" packages="faxapp.util.*"/>
      <group title="web packages" packages="faxapp.web.*"/>
      <group title="data packages" 
         packages="faxapp.entity.*:faxapp.dao.*"/>
   </javadoc>
   <echo message="java doc has been generated!" />
</target>

आइए हम javadoc चींटी के कार्य को अंजाम दें। यह जावा फोल्डर को डॉक फोल्डर में जेनरेट करता है और रखता है।

जब javadoc target निष्पादित किया जाता है, यह निम्नलिखित परिणाम उत्पन्न करता है:

C:\>ant generate-javadoc
Buildfile: C:\build.xml

java doc has been generated!

BUILD SUCCESSFUL
Total time: 10.63 second

जावा प्रलेखन फ़ाइलें अब में मौजूद हैं doc फ़ोल्डर।

आमतौर पर, javadoc फ़ाइलें रिलीज़ या पैकेज लक्ष्य के एक भाग के रूप में उत्पन्न होती हैं।

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

गुण विवरण
basedir आउटपुट JAR फ़ाइल के लिए आधार निर्देशिका। डिफ़ॉल्ट रूप से, यह प्रोजेक्ट की बेस डायरेक्टरी पर सेट है।
संकुचित करें चींटी को फ़ाइल को संक्षिप्त करने के लिए सलाह देता है क्योंकि यह JAR फ़ाइल बनाता है।
keepcompression जबकि compress विशेषता व्यक्तिगत फ़ाइलों पर लागू होती है, keepcompression विशेषता एक ही काम करती है, लेकिन यह पूरे संग्रह पर लागू होती है।
destfile आउटपुट JAR फ़ाइल का नाम।
डुप्लिकेट चींटी को सलाह देता है कि डुप्लिकेट फाइलें मिलने पर क्या करना चाहिए। आप डुप्लिकेट फ़ाइलों को जोड़, संरक्षित या विफल कर सकते हैं।
शामिल नहीं चींटी को सलाह देता है कि इन अल्पविराम से अलग की गई फाइलों को पैकेज में शामिल न करें।
excludesfile ऊपर की तरह ही, अपवर्जित फ़ाइलों को छोड़कर एक पैटर्न का उपयोग करके निर्दिष्ट किया गया है।
शामिल अपवर्जित का उलटा।
includesfile अपवर्जित का उलटा।
अपडेट करें पहले से निर्मित JAR फ़ाइल में फ़ाइलों को अधिलेखित करने के लिए चींटी को सलाह देता है।

हमारी जारी है Hello Worldफ़ैक्स एप्लिकेशन प्रोजेक्ट, हमें जार फ़ाइलों का निर्माण करने के लिए एक नया लक्ष्य जोड़ें। लेकिन इससे पहले, हम नीचे दिए गए जार कार्य पर विचार करें।

<jar destfile="${web.dir}/lib/util.jar"
   basedir="${build.dir}/classes"
   includes="faxapp/util/**"
   excludes="**/Test.class"
/>

यहां ही web.dirसंपत्ति वेब स्रोत फ़ाइलों के पथ को इंगित करती है। हमारे मामले में, यह वह जगह है जहां use.jar रखा जाएगा।

build.dir इस उदाहरण में गुण बिल्ड फ़ोल्डर की ओर इशारा करते हैं, जहाँ use.jar के लिए वर्ग फाइलें मिल सकती हैं।

इस उदाहरण में, हम एक जार फ़ाइल बनाते हैं जिसे कहा जाता है util.jar से कक्षाओं का उपयोग कर faxapp.util.*पैकेज। हालाँकि, हम उन वर्गों को शामिल नहीं कर रहे हैं जो टेस्ट नाम से समाप्त होते हैं। आउटपुट जार फ़ाइल को वेब एप्लिकेशन लिबर फ़ोल्डर में रखा जाएगा।

अगर हम यूज करना चाहते हैं। एक एग्जीक्यूटेबल जार फाइल को जोड़ना होगा manifest उसके साथ Main-Class मेटा विशेषता।

इसलिए, उपरोक्त उदाहरण के रूप में अद्यतन किया जाएगा:

<jar destfile="${web.dir}/lib/util.jar"
   basedir="${build.dir}/classes"
   includes="faxapp/util/**"
   excludes="**/Test.class">
   <manifest>
      <attribute name="Main-Class" value="com.tutorialspoint.util.FaxUtil"/>
   </manifest>
</jar>

जार कार्य को निष्पादित करने के लिए, इसे लक्ष्य के अंदर लपेटें, सबसे अधिक, निर्माण या पैकेज लक्ष्य, और उन्हें निष्पादित करें।

<target name="build-jar">
<jar destfile="${web.dir}/lib/util.jar"
   basedir="${build.dir}/classes"
   includes="faxapp/util/**"
   excludes="**/Test.class">
   <manifest>
      <attribute name="Main-Class" value="com.tutorialspoint.util.FaxUtil"/>
   </manifest>
</jar>
</target>

इस फ़ाइल पर रनिंग चींटी हमारे लिए use.jar फ़ाइल बनाती है।

निम्नलिखित परिणाम चींटी फ़ाइल को चलाने का परिणाम है:

C:\>ant build-jar
Buildfile: C:\build.xml

BUILD SUCCESSFUL
Total time: 1.3 seconds

उपयोग.जर फ़ाइल अब आउटपुट फ़ोल्डर में रखी गई है।

चींटी के साथ WAR फाइलें बनाना बेहद सरल है, और JAR फ़ाइलों के निर्माण के समान है। सब के बाद, WAR फ़ाइल, जैसे JAR फ़ाइल एक और ज़िप फ़ाइल है।

WAR टास्क JAR टास्क का एक एक्सटेंशन है, लेकिन इसमें WEB-INF / classes फोल्डर में जाने और web.xml फाइल को जेनरेट करने के लिए कुछ अच्छे जोड़-तोड़ हैं। WAR कार्य WAR फ़ाइल के किसी विशेष लेआउट को निर्दिष्ट करने के लिए उपयोगी है।

चूंकि WAR कार्य JAR कार्य का विस्तार है, इसलिए JAR कार्य की सभी विशेषताएँ WAR कार्य पर लागू होती हैं।

गुण विवरण
webxml वेब के लिए पथ। xml फ़ाइल
उदारीकरण WEB-INF \ lib फ़ोल्डर में क्या जाता है यह निर्दिष्ट करने के लिए एक समूहीकरण।
कक्षाओं WEB-INF \ classes फ़ोल्डर में क्या जाता है यह निर्दिष्ट करने के लिए एक समूहीकरण।
metainf MANIFEST.MF फ़ाइल बनाने के लिए निर्देश निर्दिष्ट करता है।

हमारी जारी है Hello Worldफ़ैक्स एप्लिकेशन प्रोजेक्ट, हमें जार फ़ाइलों का निर्माण करने के लिए एक नया लक्ष्य जोड़ें। लेकिन इससे पहले कि हम युद्ध कार्य पर विचार करें। निम्नलिखित उदाहरण पर विचार करें:

<war destfile="fax.war" webxml="${web.dir}/web.xml">
   <fileset dir="${web.dir}/WebContent">
      <include name="**/*.*"/>
   </fileset>
   <lib dir="thirdpartyjars">
      <exclude name="portlet.jar"/>
   </lib>
   <classes dir="${build.dir}/web"/>
</war>

पिछले उदाहरणों के अनुसार, web.dir चर स्रोत वेब फ़ोल्डर को संदर्भित करता है, अर्थात, वह फ़ोल्डर जिसमें JSP, css, javascript फाइलें आदि हैं।

build.dirचर आउटपुट फ़ोल्डर को संदर्भित करता है - यह वह जगह है जहां WAR पैकेज के लिए कक्षाएं मिल सकती हैं। आमतौर पर, वर्गों को वेब फ़ाइल के WEB-INF / कक्षाओं फ़ोल्डर में बंडल किया जाएगा।

इस उदाहरण में, हम फ़ैक्स.वर नामक एक युद्ध फ़ाइल बना रहे हैं। WEB.XML फ़ाइल वेब स्रोत फ़ोल्डर से प्राप्त की जाती है। वेब के अंतर्गत 'WebContent' फोल्डर की सभी फाइलों को WAR फाइल में कॉपी किया जाता है।

WEB-INF / lib फ़ोल्डर को थर्डपार्टीजर्स फ़ोल्डर से जार फ़ाइलों के साथ आबाद किया गया है। हालाँकि, हम portlet.jar को बाहर कर रहे हैं क्योंकि यह पहले से ही एप्लिकेशन सर्वर के लिबास फोल्डर में मौजूद है। अंत में, हम बिल्ड डायरेक्टरी के वेब फोल्डर से सभी कक्षाओं को कॉपी कर रहे हैं और WEB-INF / क्लासेस फोल्डर में डाल रहे हैं।

चींटी लक्ष्य (आमतौर पर पैकेज) के अंदर युद्ध कार्य को लपेटें और इसे चलाएं। यह निर्दिष्ट स्थान में WAR फ़ाइल बनाएगा।

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

युद्ध के कार्य को अंजाम देने के लिए, इसे लक्ष्य के अंदर लपेटें, सबसे अधिक, निर्माण या पैकेज लक्ष्य, और उन्हें चलाएं।

<target name="build-war">
   <war destfile="fax.war" webxml="${web.dir}/web.xml">
   <fileset dir="${web.dir}/WebContent">
      <include name="**/*.*"/>
   </fileset>
   <lib dir="thirdpartyjars">
      <exclude name="portlet.jar"/>
   </lib>
   <classes dir="${build.dir}/web"/>
   </war>
</target>

इस फ़ाइल पर रनिंग चींटी बनाएगी fax.war हमारे लिए फ़ाइल करें।

निम्नलिखित परिणाम चींटी फ़ाइल को चलाने का परिणाम है:

C:\>ant build-war
Buildfile: C:\build.xml

BUILD SUCCESSFUL
Total time: 12.3 seconds

फ़ैक्स.वर फ़ाइल अब आउटपुट फ़ोल्डर में रखी गई है। युद्ध फ़ाइल की सामग्री होगी:

fax.war:
   +---jsp             This folder contains the jsp files
   +---css             This folder contains the stylesheet files
   +---js              This folder contains the javascript files
   +---images          This folder contains the image files
   +---META-INF        This folder contains the Manifest.Mf
   +---WEB-INF
      +---classes   This folder contains the compiled classes
      +---lib       Third party libraries and the utility jar files
      WEB.xml       Configuration file that defines the WAR package

हमने चींटी के विभिन्न पहलुओं को सीखा है Hello World बिट्स और टुकड़ों में वेब अनुप्रयोग फ़ैक्स करें।

अब एक पूर्ण और पूर्ण build.xml फ़ाइल बनाने के लिए सब कुछ एक साथ रखने का समय है। विचार करेंbuild.properties तथा build.xml फाइलें इस प्रकार हैं:

build.properties

deploy.path=c:\tomcat6\webapps

build.xml

<?xml version="1.0"?>

<project name="fax" basedir="." default="usage">
   <property file="build.properties"/>
   <property name="src.dir" value="src"/>
   <property name="web.dir" value="war"/>
   <property name="javadoc.dir" value="doc"/>
   <property name="build.dir" value="${web.dir}/WEB-INF/classes"/>
   <property name="name" value="fax"/>

   <path id="master-classpath">
      <fileset dir="${web.dir}/WEB-INF/lib">
         <include name="*.jar"/>
      </fileset>
      <pathelement path="${build.dir}"/>
   </path>
    
   <target name="javadoc">
      <javadoc packagenames="faxapp.*" sourcepath="${src.dir}" 
         destdir="doc" version="true" windowtitle="Fax Application">
      <doctitle><![CDATA[<h1>= Fax Application =</h1>]]>
      </doctitle>
      <bottom><![CDATA[Copyright © 2011. All Rights Reserved.]]>
      </bottom>
      <group title="util packages" packages="faxapp.util.*"/>
      <group title="web packages" packages="faxapp.web.*"/> 
      <group title="data packages" 
         packages="faxapp.entity.*:faxapp.dao.*"/>
      </javadoc>
   </target>

   <target name="usage">
      <echo message=""/>
      <echo message="${name} build file"/>
      <echo message="-----------------------------------"/>
      <echo message=""/>
      <echo message="Available targets are:"/>
      <echo message=""/>
      <echo message="deploy    --> Deploy application as directory"/>
      <echo message="deploywar --> Deploy application as a WAR file"/>
      <echo message=""/>
   </target>

   <target name="build" description="Compile main 
      source tree java files">
   <mkdir dir="${build.dir}"/>
      <javac destdir="${build.dir}" source="1.5" 
         target="1.5" debug="true"
         deprecation="false" optimize="false" failonerror="true">
      <src path="${src.dir}"/>
      <classpath refid="master-classpath"/>
      </javac>
   </target>

   <target name="deploy" depends="build" 
      description="Deploy application">
   <copy todir="${deploy.path}/${name}" 
      preservelastmodified="true">
      <fileset dir="${web.dir}">
         <include name="**/*.*"/>
      </fileset>
   </copy>
   </target>

   <target name="deploywar" depends="build" 
      description="Deploy application as a WAR file">
      <war destfile="${name}.war"
         webxml="${web.dir}/WEB-INF/web.xml">
         <fileset dir="${web.dir}">
            <include name="**/*.*"/>
         </fileset>
      </war>
      <copy todir="${deploy.path}" preservelastmodified="true">
         <fileset dir=".">
            <include name="*.war"/>
         </fileset>
      </copy>
   </target>
    

   <target name="clean" description="Clean output directories">
      <delete>
         <fileset dir="${build.dir}">
            <include name="**/*.class"/>
         </fileset>
      </delete>
   </target>
</project>

इस उदाहरण में:

  • हम पहले बिल्ड प्रॉपर्टीज़ फ़ाइल में Tomcat में webapps फ़ोल्डर के लिए पथ घोषित करते हैं deploy.path चर।

  • हम जावा फ़ाइलों के लिए स्रोत फ़ोल्डर भी घोषित करते हैं src.dir चर।

  • फिर हम वेब फ़ाइलों के लिए स्रोत फ़ोल्डर की घोषणा करते हैं web.dir चर। javadoc.dir जावा प्रलेखन संग्रहीत करने के लिए फ़ोल्डर है, और build.dir बिल्ड आउटपुट फ़ाइलों को संग्रहीत करने के लिए पथ है।

  • फिर हम वेब एप्लिकेशन का नाम घोषित करते हैं, जो है fax हमारे मामले में।

  • हम मास्टर क्लास पथ को भी परिभाषित करते हैं जिसमें JAR फाइलें परियोजना के WEB-INF / lib फ़ोल्डर में मौजूद हैं।

  • हम इसमें मौजूद क्लास फाइल्स को भी शामिल करते हैं build.dir मास्टर वर्ग पथ में।

  • Javadoc लक्ष्य परियोजना के लिए आवश्यक javadoc का उत्पादन करता है और निर्माण लक्ष्य का उपयोग बिल्ड फ़ाइल में मौजूद सामान्य लक्ष्यों को प्रिंट करने के लिए किया जाता है।

उपरोक्त उदाहरण दो परिनियोजन लक्ष्य दिखाता है: deploy तथा deploywar.

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

स्वच्छ लक्ष्य पहले निर्मित सभी फ़ाइलों को साफ़ करता है।

तैनाती का लक्ष्य युद्ध फ़ाइल बनाता है और फिर एप्लिकेशन सर्वर की तैनाती निर्देशिका में युद्ध फ़ाइल की प्रतिलिपि बनाता है।

पिछले अध्याय में, हमने सीखा है कि किसी एप्लिकेशन को कैसे पैकेज किया जाए और इसे एक फोल्डर में तैनात किया जाए।

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

build.properties

# Ant properties for building the springapp

appserver.home=c:\\install\\apache-tomcat-7.0.19
# for Tomcat 5 use $appserver.home}/server/lib
# for Tomcat 6 use $appserver.home}/lib
appserver.lib=${appserver.home}/lib

deploy.path=${appserver.home}/webapps

tomcat.manager.url=http://www.tutorialspoint.com:8080/manager
tomcat.manager.username=tutorialspoint
tomcat.manager.password=secret

build.xml

<?xml version="1.0"?>

<project name="fax" basedir="." default="usage">
   <property file="build.properties"/>
   <property name="src.dir" value="src"/>
   <property name="web.dir" value="war"/>
   <property name="javadoc.dir" value="doc"/>
   <property name="build.dir" value="${web.dir}/WEB-INF/classes"/>
   <property name="name" value="fax"/>

   <path id="master-classpath">
      <fileset dir="${web.dir}/WEB-INF/lib">
         <include name="*.jar"/>
      </fileset>
   <pathelement path="${build.dir}"/>
   </path>
    
   <target name="javadoc">
   <javadoc packagenames="faxapp.*" sourcepath="${src.dir}" 
      destdir="doc" version="true" windowtitle="Fax Application">
      <doctitle><![CDATA[<h1>= Fax Application 
         =</h1>]]></doctitle>
      <bottom><![CDATA[Copyright © 2011. All 
         Rights Reserved.]]></bottom>
      <group title="util packages" packages="faxapp.util.*"/>
      <group title="web packages" packages="faxapp.web.*"/>
      <group title="data packages" packages="faxapp.entity.*:faxapp.dao.*"/>
   </javadoc>
   </target>

   <target name="usage">
   <echo message=""/>
   <echo message="${name} build file"/>
   <echo message="-----------------------------------"/>
   <echo message=""/>
   <echo message="Available targets are:"/>
   <echo message=""/>
   <echo message="deploy    --> Deploy application as directory"/>
   <echo message="deploywar --> Deploy application as a WAR file"/>
   <echo message=""/>
   </target>

   <target name="build" description="Compile main 
      source tree java files">
   <mkdir dir="${build.dir}"/>
   <javac destdir="${build.dir}" source="1.5" target="1.5" debug="true"
      deprecation="false" optimize="false" failonerror="true">
      <src path="${src.dir}"/>
      <classpath refid="master-classpath"/>
   </javac>
   </target>

   <target name="deploy" depends="build" description="Deploy application">
      <copy todir="${deploy.path}/${name}" 
         preservelastmodified="true">
         <fileset dir="${web.dir}">
            <include name="**/*.*"/>
         </fileset>
      </copy>
   </target>

   <target name="deploywar" depends="build" 
      description="Deploy application as a WAR file">
      <war destfile="${name}.war"
         webxml="${web.dir}/WEB-INF/web.xml">
         <fileset dir="${web.dir}">
            <include name="**/*.*"/>
         </fileset>
      </war>
      <copy todir="${deploy.path}" preservelastmodified="true">
         <fileset dir=".">
            <include name="*.war"/>
         </fileset>
      </copy>
   </target>
    

   <target name="clean" description="Clean output directories">
      <delete>
         <fileset dir="${build.dir}">
            <include name="**/*.class"/>
         </fileset>
      </delete>
   </target>
<!-- ============================================================ -->
<!-- Tomcat tasks -->
<!-- ============================================================ -->

<path id="catalina-ant-classpath">
<!-- We need the Catalina jars for Tomcat -->
<!--  * for other app servers - check the docs -->
   <fileset dir="${appserver.lib}">
      <include name="catalina-ant.jar"/>
   </fileset>
</path>

<taskdef name="install" classname="org.apache.catalina.ant.InstallTask">
   <classpath refid="catalina-ant-classpath"/>
</taskdef>
<taskdef name="reload" classname="org.apache.catalina.ant.ReloadTask">
   <classpath refid="catalina-ant-classpath"/>
</taskdef>
<taskdef name="list" classname="org.apache.catalina.ant.ListTask">
   <classpath refid="catalina-ant-classpath"/>
</taskdef>
<taskdef name="start" classname="org.apache.catalina.ant.StartTask">
   <classpath refid="catalina-ant-classpath"/>
</taskdef>
<taskdef name="stop" classname="org.apache.catalina.ant.StopTask">
   <classpath refid="catalina-ant-classpath"/>
</taskdef>

<target name="reload" description="Reload application in Tomcat">
   <reload url="${tomcat.manager.url}"username="${tomcat.manager.username}"
      password="${tomcat.manager.password}" path="/${name}"/>
</target>
</project>

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

  • appserver.home टॉमकैट एप्लिकेशन सर्वर के लिए इंस्टॉलेशन पथ के बिंदु।

  • appserver.lib टॉम्बैट इंस्टॉलेशन फ़ोल्डर में लाइब्रेरी फ़ाइलों के लिए अंक।

  • deploy.path चर अब Tomcat में वेब फ़ोल्डर फ़ोल्डर की ओर इशारा करता है।

टॉमकैट में एप्लिकेशन को रोका जा सकता है और टॉमकैट प्रबंधक एप्लिकेशन का उपयोग करना शुरू कर दिया जा सकता है। प्रबंधक एप्लिकेशन, उपयोगकर्ता नाम और पासवर्ड के लिए URL बिल्ड.properties फ़ाइल में भी निर्दिष्ट हैं। इसके बाद, हम एक नया CLASSPATH घोषित करते हैं जिसमें शामिल हैcatalina-ant.jar। इस जार फ़ाइल को Apache Ant के माध्यम से Tomcat कार्यों को निष्पादित करने के लिए आवश्यक है।

उत्प्रेरक- ant.jar निम्नलिखित कार्य प्रदान करता है:

गुण विवरण
InstallTask एक वेब अनुप्रयोग स्थापित करता है। वर्ग का नाम: org.apache.catalina.ant.InstallTask
ReloadTask एक वेब अनुप्रयोग पुनः लोड करें। क्लास का नाम: org.apache.catalina.ant.eloadTask
ListTask सभी वेब अनुप्रयोगों को सूचीबद्ध करता है। वर्ग का नाम: org.apache.catalina.ant.ListTask
StartTask एक वेब अनुप्रयोग शुरू करता है। वर्ग का नाम: org.apache.catalina.ant.StartTask
StopTask एक वेब अनुप्रयोग बंद कर देता है। वर्ग का नाम: org.apache.catalina.ant.StopTask
ReloadTask बिना रुके एक वेब एप्लिकेशन को पुनः लोड करें। क्लास का नाम: org.apache.catalina.ant.eloadTask

पुनः लोड कार्य के लिए निम्नलिखित अतिरिक्त मापदंडों की आवश्यकता होती है:

  • प्रबंधक आवेदन के लिए URL
  • वेब एप्लिकेशन को पुनः आरंभ करने के लिए उपयोगकर्ता नाम
  • वेब एप्लिकेशन को पुनरारंभ करने के लिए पासवर्ड
  • पुन: प्रारंभ किए जाने वाले वेब एप्लिकेशन का नाम

हमें जारी करते हैं deploy-warWebc को Tomcat webapps फ़ोल्डर में कॉपी करने के लिए कमांड करें और फिर फ़ैक्स वेब एप्लिकेशन को पुनः लोड करें। निम्नलिखित परिणाम चींटी फ़ाइल को चलाने का परिणाम है:

C:\>ant deploy-war
Buildfile: C:\build.xml

BUILD SUCCESSFUL
Total time: 6.3 seconds

C:\>ant reload
Buildfile: C:\build.xml

BUILD SUCCESSFUL
Total time: 3.1 seconds

एक बार उपरोक्त कार्य चलाने के बाद, वेब एप्लिकेशन को तैनात किया जाता है और वेब एप्लिकेशन को फिर से लोड किया जाता है।

आप जावा कोड को निष्पादित करने के लिए चींटी का उपयोग कर सकते हैं। निम्नलिखित उदाहरण में, जावा वर्ग एक तर्क (व्यवस्थापक का ईमेल पता) लेता है और एक ईमेल भेजता है।

public class NotifyAdministrator
{
   public static void main(String[] args)
   {
      String email = args[0];
      notifyAdministratorviaEmail(email);
      System.out.println("Administrator "+email+" has been notified");
   }
   public static void notifyAdministratorviaEmail(String email
   { 
	   //......
   }
}

यहाँ एक साधारण बिल्ड है जो इस जावा क्लास को निष्पादित करता है।

<?xml version="1.0"?>
<project name="sample" basedir="." default="notify">
   <target name="notify">
      <java fork="true" failonerror="yes" classname="NotifyAdministrator">
         <arg line="[email protected]"/>
      </java>
   </target>
</project>

जब बिल्ड निष्पादित होता है, तो यह निम्न परिणाम उत्पन्न करता है:

C:\>ant
Buildfile: C:\build.xml

notify: [java] Administrator [email protected] has been notified

BUILD SUCCESSFUL
Total time: 1 second

इस उदाहरण में, जावा कोड एक साधारण काम करता है - एक ईमेल भेजने के लिए। हम चींटी कार्य में निर्मित का उपयोग कर सकते थे। हालाँकि, अब जब आपको यह विचार मिल गया है, तो आप अपनी बिल्ड फ़ाइल को जावा कोड को कॉल करने के लिए बढ़ा सकते हैं जो जटिल चीजें करता है, उदाहरण के लिए: अपने स्रोत कोड को एन्क्रिप्ट करता है।

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

चींटी को ग्रहण में एकीकृत करने के लिए, सरल चरणों का पालन करें।

  • सुनिश्चित करें कि build.xml आपके जावा प्रोजेक्ट का एक हिस्सा है, और उस स्थान पर निवास नहीं करता है जो प्रोजेक्ट के लिए बाहरी है।

  • निम्नलिखित द्वारा चींटी को देखें Window > Show View > Other > Ant > Ant.

  • प्रोजेक्ट एक्सप्लोरर खोलें, बिल्ड.xml को चींटी व्यू में खींचें।

आपका चींटी देखने के समान है:

लक्ष्य पर क्लिक करने पर, बिल्ड / क्लीन / यूज, चींटी को लक्ष्य के साथ चलाएगा।

"फ़ैक्स" पर क्लिक करने से डिफ़ॉल्ट लक्ष्य पूरा हो जाएगा - usage.

चींटी ग्रहण प्लगइन भी build.xml फ़ाइलों के संपादन के लिए एक अच्छा संपादक के साथ आता है। संपादक build.xml स्कीमा से अवगत है और आपको कोड पूरा करने में सहायता कर सकता है।

चींटी संपादक का उपयोग करने के लिए, अपने build.xml (प्रोजेक्ट एक्सप्लोरर से) पर राइट क्लिक करें और> चींटी संपादक के साथ ओपन का चयन करें। चीफ संपादक को कुछ इसी तरह दिखना चाहिए:

चींटी संपादक दाहिने हाथ की ओर लक्ष्य को सूचीबद्ध करता है। लक्ष्य सूची एक बुकमार्क के रूप में कार्य करती है जो आपको किसी विशेष लक्ष्य के संपादन में सीधे कूदने की अनुमति देती है।

JUnit जावा-आधारित विकास के लिए आमतौर पर उपयोग की जाने वाली इकाई परीक्षण रूपरेखा है। इसका उपयोग करना आसान है और विस्तार करना आसान है। कई JUnit एक्सटेंशन उपलब्ध हैं। यदि आप JUnit से अपरिचित हैं, तो आपको इसे www.junit.org से डाउनलोड करना चाहिए और इसका मैनुअल पढ़ना चाहिए ।

इस अध्याय में दिखाया गया है कि चींटी का उपयोग करके JUnit परीक्षणों को कैसे निष्पादित करें। चींटी इसे सीधे JUnit कार्य के माध्यम से आगे बढ़ाती है।

JUnit कार्य की विशेषताएं नीचे प्रस्तुत की गई हैं:

गुण विवरण
डिर वीएम को कहां से मंगाना है। इसे कब अनदेखा किया जाता हैfork अक्षम है।
JVM कमांड जेवीएम का आह्वान करता था। इसे कब अनदेखा किया जाता हैfork अक्षम है।
कांटा एक अलग JVM में परीक्षण चलाता है
errorproperty संपत्ति का नाम अगर वहाँ एक JUnit त्रुटि है सेट करने के लिए
failureproperty संपत्ति का नाम अगर वहाँ एक JUnit विफलता है सेट करने के लिए
haltonerror परीक्षण त्रुटि होने पर निष्पादन रोक देता है
haltonfailure विफलता होने पर निष्पादन रोक देता है
printsummary चींटी को प्रत्येक परीक्षण के लिए सरल आँकड़े प्रदर्शित करने की सलाह देता है
showoutput चींटी को अपने लॉग और फ़ॉर्मेटर्स को आउटपुट भेजने की सलाह देता है
tempdir चींटी जिस अस्थायी फ़ाइल का उपयोग करेगी, उसका पथ
समय समाप्त इस सेटिंग (मिलीसेकंड में) की तुलना में परीक्षण को चलाने में अधिक समय लगता है।

आइए हम विषय को जारी रखें Hello World वेब एप्लिकेशन फ़ैक्स करें और JUnit लक्ष्य जोड़ें।

निम्न उदाहरण एक सरल JUnit परीक्षण निष्पादन दिखाता है:

<target name="unittest">
   <junit haltonfailure="true" printsummary="true">
      <test name="com.tutorialspoint.UtilsTest"/>
   </junit>
</target>

यह उदाहरण com.tutorialspoint.UtilsTest जूनियर वर्ग पर JUnit के निष्पादन को दर्शाता है। उपरोक्त कोड चलाने से निम्नलिखित आउटपुट उत्पन्न होते हैं:

test:
[echo] Testing the application
[junit] Running com.tutorialspoint.UtilsTest
[junit] Tests run: 12, Failures: 0, Errors: 0, Time elapsed: 16.2 sec
BUILD PASSED

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

कस्टम चींटी कार्य का विस्तार करना चाहिए org.apache.tools.ant.Taskवर्ग और निष्पादन () विधि का विस्तार करना चाहिए। नीचे एक सरल उदाहरण दिया गया है:

package com.tutorialspoint.ant;
import org.apache.tools.ant.Task;
import org.apache.tools.ant.Project;
import org.apache.tools.ant.BuildException;
public class MyTask extends Task {
   String message;
   public void execute() throws BuildException {
      log("Message: " + message, Project.MSG_INFO);
   }
   public void setMessage(String message) {
      this.message= message;
   }
}

कस्टम कार्य को निष्पादित करने के लिए, आपको निम्नलिखित को जोड़ना होगा Hello World फैक्स वेब अनुप्रयोग:

<target name="custom">
   <taskdef name="custom" classname="com.tutorialspoint.ant.MyTask" />
   <custom message="Hello World!"/>
</target>

उपरोक्त कस्टम कार्य निष्पादित करने पर संदेश 'हैलो वर्ल्ड!'

c:\>ant custom
test:
[custom] Message : Hello World!
elapsed: 0.2 sec
BUILD PASSED

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

छाप