java best - कोणीय 2 + जावा मेवेन वेब अनुप्रयोग को एकीकृत करने के लिए कैसे





apps for (5)


मैं अनुशंसा करता हूं कि दो अनुप्रयोग अलग हो जाएं, इस तरह आपके पास मॉड्यूलरिटी है। इस तरह आप अपनी सेवा को प्रभावित किए बिना कोणीय ऐप बदल सकते हैं, और इसके विपरीत। दूसरे के लिए, आपका अपाचे / nginx एंगुलर के बजाय टॉमकैट (उदाहरण के लिए) से अपने जेएस और एचटीएमएल को वितरित करने के लिए तेज़ है। लेकिन यदि आप अभी भी युद्ध के अंदर कोणीय अनुप्रयोग रखना चाहते हैं, तो पैटर्न यह है कि सभी वेब संसाधन src / main / webapp में हैं।

मैंने एक कोणीय 2 फ्रंट एंड एप्लिकेशन बनाया है। और मैंने एक जावा रेस्ट डब्ल्यूएस बैक-एंड एप्लिकेशन बनाया है जो डीबी से जुड़ा हुआ है।

कोणीय 2 ऐप के लिए मेरा फ़ोल्डर संरचना नीचे है-

  • Angular2App
    • confg
    • जिले
    • E2E
    • node_modules
    • जनता
    • src
      • एप्लिकेशन
      • favicon.ico
      • index.html
      • main.ts
      • सिस्टम-config.ts
      • tsconfig.json
      • typings.d.ts
    • tmp
    • typings
    • .editorconfig
    • .gitignore
    • कोणीय cli.json
    • कोणीय CLI-build.js
    • package.json
    • README.md
    • tslint.json
    • typings.json

और मेरा जावा मेवेन वेब अनुप्रयोग संरचना नीचे है-

  • JerseyWebApp
    • src
      • मुख्य
      • जावा
        • कस्टम पैकेज
        • जावा कक्षाएं
      • साधन
      • वेब अप्प
        • वेब-INF
        • web.xml
        • index.html
    • pom.xml

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




मैंने जो किया था यह रहा:-

  • नोडजेस v6.9 + स्थापित करें
  • कोणीय सीएलआई के लिए @ कोणीय / cli -g स्थापित एनपीएम चलाएं
  • अपाचे मेवेन स्थापित करें या किसी भी मैवेन फ्रेंडली आईडीई का उपयोग करें
  • अपने आवश्यक मेवेन कॉन्फ़िगरेशन का उपयोग करें, मैंने सरल वेबपैप (WAR) का उपयोग किया था।

निर्देशिका स्थिरता ( ngapp फ़ोल्डर आराम के अलावा मानक मैवेन संरचना है।)

ngfirst
├── pom.xml
├── src
│   └── main
│       ├── java
│       ├── resources
│       ├── webapp
│       └── ngapp

कोणीय भाग

टर्मिनल में ngapp फ़ोल्डर खोलें और node और npm कॉन्फ़िगरेशन प्रारंभ करने के लिए ng init कमांड टाइप करें, परिणाम एक साधारण Angular2 उदाहरण एप्लिकेशन होगा ngapp फ़ोल्डर के अंदर निम्न निर्देशिका संरचना: -

             ├── angular-cli.json
             ├── e2e
             ├── karma.conf.js
             ├── node_modules
             ├── package.json
             ├── protractor.conf.js
             ├── README.md
             ├── tslint.json
             ├── src
                 ├── app
                 ├── assets
                 ├── environments
                 ├── favicon.ico
                 ├── index.html
                 ├── main.ts
                 ├── polyfills.ts
                 ├── styles.css
                 ├── test.ts
                 └── tsconfig.json

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

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

"outDir": "../webapp/ng"

इस बिंदु पर एनजी बिल्ड कमांड एनजीएफस्ट / src / main / webapp फ़ोल्डर की निर्देशिका में एनजीआरएल अनुप्रयोग का निर्माण करेगा।

मेवेन पार्ट

Pom.xml खोलें और निम्नलिखित तीन मेवेन प्लगइन्स को कॉन्फ़िगर करें: -

  1. कंपाइलर-प्लगइन : कोई जावा सामग्री / src / main / ngapp फ़ोल्डर में संकलित करने के लिए, इसे बाहर निकालें।
  2. युद्ध-प्लगइन : / src / main / ngapp कोणीय प्रोजेक्ट फ़ोल्डर है और इसे WAR में पैक नहीं किया जाना चाहिए, इसे बाहर निकालें।
  3. निष्पादन-प्लगइन : एनपीएम इंस्टॉल और एंगुलर-सीएलआई निष्पादित करें अंतिम पैकेजिंग के लिए वेबपैप फ़ोल्डर में कोणीय अनुप्रयोग उत्पन्न करने के लिए कमांड बनाएं। नोट --बेस-href तर्क, वेबपैड के संदर्भ पथ से कोणीय संसाधन लोड करना आवश्यक है।

यहां बताया गया है कि यह कैसा दिखना चाहिए: -

<plugins>
    <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>3.3</version>
        <configuration>
            <excludes>
                <exclude>ngapp/**</exclude>
            </excludes>
        </configuration>
    </plugin>
    <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-war-plugin</artifactId>
        <version>3.0.0</version>
        <configuration>
            <excludes>
                <exclude>ngapp/**</exclude>
            </excludes>
        </configuration>
    </plugin>
    <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>exec-maven-plugin</artifactId>
        <version>1.5.0</version>
        <executions>
            <execution>
                <id>exec-npm-install</id>
                <phase>generate-sources</phase>
                <configuration>
                    <workingDirectory>${project.basedir}/src/main/ngapp</workingDirectory>
                    <executable>npm</executable>
                    <arguments>
                        <argument>install</argument>
                    </arguments>
                </configuration>
                <goals>
                    <goal>exec</goal>
                </goals>
            </execution>
            <execution>
                <id>exec-npm-ng-build</id>
                <phase>generate-sources</phase>
                <configuration>
                    <workingDirectory>${project.basedir}/src/main/ngapp</workingDirectory>
                    <executable>ng</executable>
                    <arguments>
                        <argument>build</argument>
                        <argument>--base-href=/ngfirst/ng/</argument>
                    </arguments>
                </configuration>
                <goals>
                    <goal>exec</goal>
                </goals>
            </execution>
        </executions>
    </plugin>
</plugins>  

बिल्डिंग मेवेन प्रोजेक्ट (और कोणीय ऐप भी)

प्रोजेक्ट रूट फ़ोल्डर ngfirst में ओपन टर्मिनल और एमवीएन पैकेज कमांड चलाएं, इससे लक्ष्य फ़ोल्डर में एक WAR फ़ाइल (ngfirst.war) उत्पन्न होगी।

एक कंटेनर में ngfirst.war को तैनात करें, ब्राउज़र में http://localhost:8080/ngfirst/ng/index.html । (यदि आवश्यक हो तो अपना होस्टनाम और पोर्ट समायोजित करें)

अगर सब ठीक हो गया, तो आपको ऐप काम देखना चाहिए ! ब्राउज़र में, यह काम पर कोणीय आवेदन है !!

जेएसपी प्री-प्रोसेसिंग

हम कोणीय अनुप्रयोग के साथ जेएसपी प्रौद्योगिकी की गतिशील कॉन्फ़िगरेशन और पृष्ठ प्रतिपादन क्षमताओं का लाभ उठा सकते हैं, इस मामले में जावा कंटेनर द्वारा नियमित रूप से HTML पृष्ठ, index.html के रूप में कोणीय एसपीए की सेवा की जाती है, अगर हम जेएसपी इंजन को एचटीएमएल फाइलों को प्री-प्रोसेस करने के लिए भी कॉन्फ़िगर करते हैं, तो सभी जेएसपी जादू को कोणीय एसपीए पेज के अंदर शामिल किया जा सकता है, बस वेब.एक्सएमएल के अंदर निम्नलिखित शामिल करें

<servlet-mapping>
    <servlet-name>jsp</servlet-name>
    <url-pattern>*.html</url-pattern>
</servlet-mapping>

बचाओ, मेवेन परियोजना का पुनर्निर्माण, युद्ध और voila तैनात !!




काफी हद तक, मैंने पिछले हफ्ते ऐसा किया था!

नेटबीन्स 8.1 और एक टोमकैट सर्वलेट संस्करण 8.0.27 का उपयोग करना

कोणीय और जावा परियोजना फ़ाइल संरचना।

जावा प्रोजेक्ट को फू कहा जाता है। कोणीय परियोजना बार है

Foo (Java Maven Project)
|__ src
|    |__ main
|    |    |__ webapp (This folder contains the entire Angular Project)
|    |    |    |__ META-INF
|    |    |    |    \__ context.xml 
|    |    |    |__ WEB-INF
|    |    |    |    \__ web.xml
|    |    |    |__ includes
|    |    |    |    |__ css
|    |    |    |    |__ images
|    |    |    |    \__ js
|    |    |    |
|    |    |    | ## Bar project files are located here ##
|    |    |    |
|    |    |    |__ app
|    |    |    |    \__ All .ts and compiled .js files are located here
|    |    |    |__ node_modules
|    |    |    |    \__ any dependencies used for Bar are located here
|    |    |    |__ typings
|    |    |    |    \__ typings for Typescript located here
|    |    |    |
|    |    |    |__ README.txt
|    |    |    |__ index.jsp
|    |    |    |__ package.json
|    |    |    |__ systemjs.config.js
|    |    |    |__ tsconfig.json
|    |    |    |__ typings.json
|    |    |    \ ## Bar project files end here
|    |    | 
|    |    |__ resources
|    |    |    |__META-INF
|    |    |    |    \__ persistence.xml
|    |    |__ java
|    |    |    |__ hibernate.cfg.xml
|    |    |    |__ com
|    |    |    |    |__ orgName
|    |    |    |    |    |__ packageName
|    |    |    |    |    |    \__ .java files are here
|__ pom.xml
\__ nb-configuration.xml



मेरी तरफ मेरे पास प्रोजे-एंजुलर नामक कोणीय स्रोतों के लिए एक मेवेन मॉड्यूल है, और एनजेर एक युद्ध अनुप्रयोग के लिए प्रोजे-वार कहा जाता है।

पहला prj कोणीय बनाया गया है:

  • यह npm install और ng build (कॉल @J_Dev के लिए धन्यवाद) कॉल npm install के लिए मेवेन-एक्जिक-प्लगइन का उपयोग करता है!
  • संसाधन डिफ़ॉल्ट निर्देशिका को दूर dist/
  • जार मैनिफ़ेस्ट पीढ़ी छोड़ें
  • मेवेन मॉड्यूल परिणाम: जेनरेटेड कोणीय डिस्ट / सामग्री के साथ केवल एक जार!

फिर, दूसरा prj_war निर्माण है:

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

मैंने उपयोग किए गए संबंधित प्लगइन कॉन्फ़िगरेशन के तहत अनुसरण करें:

prj कोणीय (pom.xml निकालने)

<build>
    <resources>
        <resource>
            <directory>dist</directory>
        </resource>
    </resources>
    <plugins>
        <!-- skip compile -->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <executions>
                <execution>
                    <id>default-compile</id>
                    <phase />
                </execution>
            </executions>
        </plugin>
        <plugin>
            <groupId>org.codehaus.mojo</groupId>
            <artifactId>exec-maven-plugin</artifactId>
            <executions>
                <execution>
                    <id>exec-npm-install</id>
                    <phase>generate-sources</phase>
                    <configuration>
                        <workingDirectory>${project.basedir}</workingDirectory>
                        <executable>npm.cmd</executable>
                        <arguments>
                            <argument>install</argument>
                        </arguments>
                    </configuration>
                    <goals>
                        <goal>exec</goal>
                    </goals>
                </execution>
                <execution>
                    <id>exec-npm-ng-build</id>
                    <phase>generate-sources</phase>
                    <configuration>
                        <workingDirectory>${project.basedir}/src</workingDirectory>
                        <executable>ng.cmd</executable>
                        <arguments>
                            <argument>build</argument>
                            <argument>--no-progress</argument>
                            <argument>--base-href=/app/ng/</argument> <== to update
                        </arguments>
                    </configuration>
                    <goals>
                        <goal>exec</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <configuration>
                <archive>
                    <addMavenDescriptor>false</addMavenDescriptor>
                    <manifest>
                        <addClasspath>false</addClasspath>
                    </manifest>
                </archive>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-shade-plugin</artifactId>
            <executions>
                <execution>
                    <phase>package</phase>
                    <goals>
                        <goal>shade</goal>
                    </goals>
                    <configuration>
                        <filters>
                            <filter>
                                <artifact>*:*</artifact>
                                <excludes>
                                    <exclude>META-INF/</exclude>
                                </excludes>
                            </filter>
                        </filters>
                    </configuration>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

prj युद्ध (pom.xml निकालने)

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-dependency-plugin</artifactId>
            <executions>
                <execution>
                    <id>unpack angular distribution</id>
                    <phase>generate-resources</phase>
                    <goals>
                        <goal>unpack</goal>
                    </goals>
                    <configuration>
                        <artifactItems>
                            <artifactItem>
                                <groupId>com.myapp</groupId> <== to update
                                <artifactId>prj-angular</artifactId> <== to update
                                <overWrite>true</overWrite>
                                <includes>**/*</includes>
                            </artifactItem>
                        </artifactItems>
                        <outputDirectory>${project.build.directory}/prjwar/ng</outputDirectory> <== to update
                        <overWriteReleases>true</overWriteReleases>
                        <overWriteSnapshots>true</overWriteSnapshots>
                    </configuration>
                </execution>
            </executions>
        </plugin>



हम एक स्ट्रिंग मान को एक पूर्णांक मान में परिवर्तित करने के लिए Integer रैपर वर्ग की parseInt(String str) विधि का उपयोग कर सकते हैं।

उदाहरण के लिए:

String strValue = "12345";
Integer intValue = Integer.parseInt(strVal);

Integer क्लास भी valueOf(String str) विधि प्रदान करता है:

String strValue = "12345";
Integer intValue = Integer.valueOf(strValue);

हम रूपांतरण के लिए उपयोगिता वर्ग के नंबर toInt(String strValue) का भी उपयोग कर सकते हैं:

String strValue = "12345";
Integer intValue = NumberUtils.toInt(strValue);




java web-applications typescript angular maven-plugin