अपाचे CXF - त्वरित गाइड
आज के परिवेश में, आप कई विकल्पों का उपयोग करके एक वेब सेवा एप्लिकेशन बना सकते हैं। आप संचार के लिए कई मानक और व्यापक रूप से स्वीकृत प्रोटोकॉल में से एक या अधिक का उपयोग कर सकते हैं। उदाहरण के लिए SOAP , XML / HTTP, RESTful HTTP , और CORBA (कॉमन ऑब्जेक्ट रिक्वेस्ट ब्रोकर आर्किटेक्चर, जो पुराने जमाने में बहुत लोकप्रिय था, लेकिन अब ऐसा अक्सर उपयोग नहीं किया जाता है।
आपके पास HTTP, JMS , JBI जैसे अलग-अलग ट्रांसपॉर्ट का विकल्प भी है और फ्रंट-एंड एपीआई जैसे JAX-RS और JAX-WS का विकल्प भी है । वेब सेवा के विकास के लिए बहुत सारे विकल्प होने के नाते, उपरोक्त सभी विकल्पों को एक साथ गोंद करने के लिए एक ओपन सोर्स सर्विसेज फ्रेमवर्क की आवश्यकता है और यही अपाचे सीएक्सएफ करता है।
इस ट्यूटोरियल में, आप सीखेंगे कि एक वेब सेवा और एक ग्राहक जो सेवा का उपभोग करता है, को बनाने के लिए सीएक्सएफ का उपयोग कैसे करें, जो हमने ऊपर सूचीबद्ध किए हैं। यह ट्यूटोरियल सर्वर और क्लाइंट दोनों के लिए संपूर्ण कोड डेवलपमेंट के माध्यम से चलेगा। चूंकि प्रत्येक एप्लिकेशन प्रत्येक श्रेणी से केवल एक विकल्प का उपयोग कर सकता है, अर्थात् फ्रंटएंड, ट्रांसपोर्ट और प्रोटोकॉल, इन तीनों के सभी क्रमपरिवर्तन और संयोजनों को देखते हुए, आवेदनों की संख्या अत्यधिक होगी।
यह ट्यूटोरियल निम्नलिखित परियोजनाओं के विकास पर विस्तार से चर्चा करता है -
सादा पुरानी अपाचे CXF ऑब्जेक्ट्स (POJO) के साथ CXF
JAX-WS के साथ CXF
डब्ल्यूएसडीएल के साथ सीएक्सएफ
JAX-RS के साथ CXF
JMS के साथ CXF
इसे सरल रखने के लिए, हमने इसके कमांड लाइन इंटरफेस के साथ मावेन का उपयोग किया है। मावेन प्रोजेक्ट बनाने के लिए आप अपनी पसंदीदा आईडीई का उपयोग कर सकते हैं।
अगले अध्याय में, हम पहले वाले से शुरुआत करते हैं।
इस अध्याय में, आप सीखेंगे कि एक सरल वेब एप्लिकेशन कैसे विकसित किया जाए जो उपयोगकर्ता को शुभकामना संदेश भेजता है। एक वेब सेवा परियोजना WSDL मॉडल का उपयोग करती है । सीएक्सएफ आपको इस डब्ल्यूएसडीएल मॉडल को छिपाने की अनुमति देता है ताकि अपाचे सीएक्सएफ एपीआई को अंतर्निहित डब्ल्यूएसडीएल को मैप करने के लिए एक सरल दृश्य प्रदान किया जा सके।
इस सरलतम परियोजना में, वेब सेवा का इंटरफ़ेस ग्राहक के सामने सीधे आ जाएगा और ग्राहक वेब सेवा को कॉल करने के लिए देशी अपाचे सीएक्सएफ एपीआई का उपयोग करेगा।
सबसे पहले, हम एक वेब सेवा बनाएंगे। प्रत्येक सेवा में एक इंटरफ़ेस होता है जो क्लाइंट के सामने आता है। हम इस इंटरफ़ेस को साधारण Apache CXF इंटरफ़ेस या WSDL दस्तावेज़ के रूप में लिख सकते हैं। इस अपाचे सीएक्सएफ-फर्स्ट एप्रोच में हम अपाचे सीएक्सएफ इंटरफेस के माध्यम से अपनी सेवा का खुलासा करेंगे।
वेब सेवा का विकास करना
वेब पर हम जो सेवा बनाने जा रहे हैं, उसमें एक एकल वेब विधि होगी, जिसे कहा जाएगा greetings। विधि एक लेता हैstringतर्क टाइप करें जिसमें हम उपयोगकर्ता का नाम भेजेंगे। सेवा कॉल करने वाले को संदेश में शामिल उपयोगकर्ता नाम के साथ शुभकामना संदेश भेज देगी।
वेब सेवा इंटरफ़ेस
हमारी वेब सेवा के इंटरफ़ेस को बेनकाब करने के लिए, हम एक अपाचे सीएक्सएफ इंटरफ़ेस बनाएंगे जो निम्नानुसार है -
//HelloWorld.java
package com.tutorialspoint.cxf.pojo;
public interface HelloWorld {
String greetings(String text);
}
इंटरफ़ेस में केवल एक विधि है जिसे कॉल किया जाता है greetings। सर्वर इस इंटरफ़ेस को लागू करेगा। हमारे तुच्छ एप्लिकेशन में, यह इंटरफ़ेस क्लाइंट के लिए सीधे उजागर होता है। आमतौर पर, वेब सेवा एप्लिकेशन में, आप वेब सेवा इंटरफ़ेस का वर्णन करने के लिए WSDL का उपयोग करते हैं। इस सरल एप्लिकेशन में, हम क्लाइंट डेवलपर को यह प्रत्यक्ष इंटरफ़ेस प्रदान करेंगे। क्लाइंट तब कॉल करेगाgreetingsसर्वर ऑब्जेक्ट पर संदेश। तो पहले वेब सेवा बनाते हैं।
वेब सेवा कार्यान्वयन
HelloWorld में इंटरफ़ेस लागू किया गया है HelloWorldImpl नीचे दिए गए अनुसार अपाचे सीएक्सएफ क्लास -
//HelloWorldImpl.java
package com.tutorialspoint.cxf.pojo;
public class HelloWorldImpl implements HelloWorld {
@Override
public String greetings(String text) {
return "Hi " + text;
}
}
greetings विधि का एक पैरामीटर प्राप्त करता है string प्रकार, इसे एक बधाई संदेश में जोड़ता है और कॉलर को परिणामी स्ट्रिंग देता है।
अगला, हम होस्ट करने के लिए सर्वर एप्लिकेशन लिखते हैं HelloWorld सर्विस।
सर्वर बनाना
सर्वर एप्लिकेशन में दो भाग होते हैं -
पहला भाग हमारी वेब सेवा के लिए एक कारखाना बनाता है, और
दूसरा भाग a लिखता है main इसे तुरंत करने की विधि।
सर्वर का उपयोग करता है ServerFactoryBean सीएक्सएफ पुस्तकालयों द्वारा प्रदान की जाने वाली कक्षा हमारे सामने आने के लिए HelloWorldदूरदराज के ग्राहकों के लिए इंटरफ़ेस। इस प्रकार, हम पहले तुरंतServerFactoryBean वर्ग और फिर इसके विभिन्न गुण सेट करें -
ServerFactoryBean factory = new ServerFactoryBean();
हम कॉल करने के लिए कॉल करने के लिए सेवा वर्ग सेट करते हैं setServiceClass पर विधि factory वस्तु -
factory.setServiceClass(HelloWorld.class);
हम कारखाने की कॉल करके अपनी सेवा को कॉल करने के लिए URL सेट करते हैं setAddressतरीका। ध्यान दें कि सेवा इस URL पर प्रकाशित की जाएगी।
factory.setAddress("http://localhost:5000/Hello");
इस स्थिति में, सेवा एम्बेडेड सर्वर पर तैनात है और 5000 पोर्ट को सुन रही होगी। आप अपनी पसंद के किसी भी पोर्ट नंबर का विकल्प चुन सकते हैं।
कारखाना बनाने से पहले, आपको हमारे सेवा कार्यान्वयन वर्ग के बारे में कारखाने को बताना होगा। यह कॉल करके किया जाता हैsetServiceBean पर विधि factory वस्तु को यहाँ दिखाया गया है -
factory.setServiceBean(new HelloWorldImpl());
सेवा बीन हमारे सेवा कार्यान्वयन वर्ग के उदाहरण के लिए सेट है। अंत में, हम कारखाने को इसकी कॉल करके बनाते हैंcreate विधि -
factory.create();
अब, जैसा कि हमने अपनी वेब सेवा को चलाने के लिए कारखाना विकसित किया है, हम अगले एक लिखेंगे main इसे इंस्टेंट करने की विधि और इसे कुछ समय के लिए चालू रखें।
अब, एक लिखें main त्वरित करने की विधि HelloServer निम्नानुसार वर्ग -
public static void main(String[] args) throws Exception {
new HelloServer();
System.out.println("Listening on port 5000 ...");
}
एक बार तात्कालिक, ए HelloServerकक्षा अनिश्चित काल तक चलती रहेगी। उत्पादन परिनियोजन के लिए, आप निश्चित रूप से अपने सर्वर को हमेशा चालू रखेंगे। वर्तमान स्थिति में, हम एक पूर्वनिर्धारित समय के बाद सर्वर को समाप्त करेंगे।
Thread.sleep(5 * 60 * 1000);
System.out.println("Server exiting ...");
System.exit(0);
के लिए पूरा कोड HelloServer कक्षा नीचे दी गई है -
//HelloServer.java
//HelloServer.java
package com.tutorialspoint.cxf.pojo;
import org.apache.cxf.frontend.ServerFactoryBean;
public class HelloServer {
protected HelloServer() throws Exception {
ServerFactoryBean factory = new ServerFactoryBean();
factory.setServiceClass(HelloWorld.class);
factory.setAddress("http://localhost:5000/Hello");
factory.setServiceBean(new HelloWorldImpl());
factory.create();
}
public static void main(String[] args) throws Exception {
new HelloServer();
System.out.println("Listening on port 5000 ...");
Thread.sleep(5 * 60 * 1000);
System.out.println("Server exiting ...");
System.exit(0);
}
}
सर्वर एप्लिकेशन जो हमने बनाया है वह उपयोग करता है ServerFactoryBeanसीएक्सएफ पुस्तकालयों से वर्ग। हमें अब इन पुस्तकालयों को सफलतापूर्वक संकलित करने के लिए अपनी परियोजना में शामिल करना चाहिएHelloServerकक्षा। हम इस्तेमाल करेंगेMaven परियोजना निर्भरता को स्थापित करने के लिए।
मावेन परियोजना की स्थापना
मावेन प्रोजेक्ट बनाने के लिए, अपनी कमांड-लाइन विंडो में निम्न कमांड टाइप करें। ध्यान दें कि हमने मैक मशीन पर इसका परीक्षण किया है। विंडोज और लिनक्स इंस्टॉलेशन के लिए, निर्देश कुछ स्थानों पर भिन्न हो सकते हैं।
mvn archetype:generate
गुणों के लिए पूछे जाने पर, निम्न मान इनपुट करें -
Define value for property 'groupId': : com.tutorialspoint
Define value for property 'artifactId': : cxf-pojo
Define value for property 'version': 1.0-SNAPSHOT: : 1.0
Define value for property 'package': com.tutorialspoint: : com.tutorialspoint.cxf.pojo
मावेन कमांड के पूरा होने पर, आपको अपने वर्तमान फ़ोल्डर में pom.xml फ़ाइल के साथ उपयुक्त फ़ोल्डर संरचना मिलेगी।
उत्पन्न निर्देशिका संरचना यहाँ दिखाई गई है -
आप सीएक्सएफ निर्भरता में जोड़ देंगे pom.xmlऔर मावेन निर्मित संरचना के उपयुक्त फ़ोल्डर में उपरोक्त बनाई गई अपाचे सीएक्सएफ फाइलों को भी कॉपी करें। आपके तैयार संदर्भ के लिए, हमने अपने मशीन पर बनाए गए प्रोजेक्ट के लिए pom.xml फ़ाइल नीचे दी है।
<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0" xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.tutorialspoint</groupId>
<artifactId>cxf-pojo</artifactId>
<version>1.0</version>
<packaging>jar</packaging>
<profiles>
<profile>
<id>server</id>
<build>
<defaultGoal>test</defaultGoal>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
</goals>
<configuration>
<mainClass>
com.tutorialspoint.cxf.pojo.HelloServer
</mainClass>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
<profile>
<id>client</id>
<build>
<defaultGoal>test</defaultGoal>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
</goals>
<configuration>
<mainClass>
com.tutorialspoint.cxf.pojo.HelloClient
</mainClass>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
</profiles>
<dependencies>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-features-logging</artifactId>
<version>3.3.0</version>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-frontend-simple</artifactId>
<version>3.3.0</version>
<type>jar</type>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-frontend-jaxws</artifactId>
<version>3.3.0</version>
</dependency>
<!-- Jetty is needed if you're using the CXFServlet -->
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http-jetty</artifactId>
<version>3.3.0</version>
</dependency>
</dependencies>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
</project>
उपरोक्त pom.xml में अतिरिक्त निर्भरताएं शामिल हो सकती हैं जो इस परियोजना के लिए अप्रासंगिक हैं, लेकिन इस ट्यूटोरियल में हमारी अगली परियोजना के लिए आवश्यक हैं। वैसे भी, अतिरिक्त निर्भरता सहित इस तरह की कोई हानि नहीं है।
प्रोजेक्ट फ़ोल्डर संरचना
सर्वर और क्लाइंट Apache CXF फाइलें रखने के बाद मेरी मशीन पर प्रोजेक्ट फ़ोल्डर संरचना आपके त्वरित संदर्भ के लिए नीचे दिखाई गई है -
चल रहा सर्वर
प्रोजेक्ट बनाने के लिए, अपनी कमांड-लाइन विंडो में निम्न कमांड का उपयोग करें -
mvn clean install
आप निम्न कमांड का उपयोग करके सर्वर शुरू कर सकते हैं -
mvn -Pserver
यह सर्वर को शुरू करेगा और आपको कंसोल पर निम्नलिखित संकेत दिखाई देगा -
INFO: Creating Service {http://pojo.cxf.tutorialspoint.com/}HelloWorld from class com.tutorialspoint.cxf.pojo.HelloWorld
INFO: Setting the server's publish address to be http://localhost:5000/Hello
Listening on port 5000 ...
अब, आपकी ब्राउज़र विंडो में हमारी प्रकाशित सेवा का URL निर्दिष्ट है। आप निम्न आउटपुट देखेंगे -
यह पुष्टि करता है कि हमारी सेवा किसी लोकलहोस्ट पर निर्दिष्ट पोर्ट पर चल रही है। चूंकि हमने निर्दिष्ट नहीं किया हैgreetings हमारे कॉल में संदेश, एक SOAP गलती संदेश ब्राउज़र पर वापस आ जाता है।
आप अपनी पसंद के SOAP क्लाइंट का उपयोग करके अपनी वेब सेवा का और परीक्षण कर सकते हैं। यहां हमने अपने सर्वर का परीक्षण करने के लिए पोस्टमैन का उपयोग किया है।
आउटपुट यहाँ दिखाया गया है -
उसका अवलोकन करो SOAP Requestहाथ से कोडित किया गया था। अनुरोध पोस्ट करने के बाद, सर्वर ने भेजाSOAP Response संदेश, जो स्क्रीन शॉट के निचले हिस्से में देखा जाता है।
इससे, आप समझ सकते हैं कि सीएक्सएफ अनुरोध और प्रतिक्रिया दोनों के लिए एसओएपी प्रोटोकॉल के उपयोग को बनाए रखता है, जबकि यह आपको विभिन्न प्रकार की वेब प्रौद्योगिकियों के लिए एकीकृत दृष्टिकोण प्रदान करता है जो आज की दुनिया में मौजूद हैं। यह वेब अनुप्रयोग विकास को बहुत सरल करता है।
हमारा अगला काम एक ग्राहक बनाना है जो आपके द्वारा बनाई गई वेब सेवा का उपभोग करेगा।
ग्राहक बनाना
सर्वर एप्लिकेशन में HelloWorldवह इंटरफ़ेस है जो हमारी वेब सेवा को उजागर करता है। वेब सेवा ही ग्राहक को एक सादा ग्रीटिंग संदेश प्रदान करती है। आमतौर पर, वेब सेवा इंटरफ़ेस को WSDL (वेब सेवा विवरण भाषा) का उपयोग करके बाहरी दुनिया के लिए उजागर किया जाता है। इस तुच्छ अनुप्रयोग में, हम सीधे सेवा इंटरफ़ेस को उजागर करके ग्राहक को हमारी वेब सेवा का खुलासा करेंगे और यह हैHelloWorld.class।
इस उद्देश्य के लिए, सीएक्सएफ नामक एक कारखाना वर्ग प्रदान करता है ClientProxyFactoryBean जो हमें बनाए गए कारखाने के उदाहरण के लिए वांछित इंटरफ़ेस से जुड़ने की अनुमति देता है।
सबसे पहले, हम एक कारखाना सेम उदाहरण बनाते हैं -
ClientProxyFactoryBean factory = new ClientProxyFactoryBean();
हम कहते हैं setAddressURL सेट करने के लिए फ़ैक्टरी बीन इंस्टेंस पर विधि जिसके द्वारा हमारी वेब सेवा को लागू किया जा सकता है। हमारे मामले में, हम अपने पहले चरण में सर्वर बनाते समय उपयोग किए गए URL का उपयोग करेंगे -
factory.setAddress("http://localhost:5000/Hello");
इसके बाद, हम कॉल करते हैं create पर विधि factory उदाहरण हमारे सेवा इंटरफ़ेस को संलग्न करने के लिए HelloWorld.class यह करने के लिए।
HelloWorld helloServer = factory.create(HelloWorld.class);
अंत में, हम कहते हैं greetings दूरस्थ वेब सेवा को लागू करने की विधि।
System.out.println(helloServer.greetings(System.getProperty("user.name")));
यह आपके कंसोल पर बधाई संदेश प्रिंट करेगा।
ग्राहक आवेदन के लिए पूरा स्रोत नीचे दिखाया गया है -
//HelloClient.java
package com.tutorialspoint.cxf.pojo;
import org.apache.cxf.frontend.ClientProxyFactoryBean;
public class HelloClient {
public static void main(String[] args) throws Exception {
ClientProxyFactoryBean factory = new ClientProxyFactoryBean();
factory.setAddress("http://localhost:5000/Hello");
HelloWorld helloServer = factory.create(HelloWorld.class);
System.out.println(helloServer.greetings(System.getProperty("user.name")));
}
}
चल रहा है ग्राहक
सुनिश्चित करें कि सर्वर अभी भी आपकी मशीन पर चल रहा है। यदि यह समाप्त हो गया है, तो मामले में, निम्नलिखित कमांड के साथ सर्वर को पुनरारंभ करें -
mvn -Pserver
आपको कंसोल पर निम्न संदेश दिखाई देगा -
Listening on port 5000 ...
अब, सर्वर समय से पहले जिसे हमने 5 मिनट के लिए सेट किया है, एक और कमांड लाइन विंडो खोलें और क्लाइंट को निम्न कमांड के साथ शुरू करें -
mvn -Pclient
आपको कमांड लाइन पर निम्न के जैसा एक संदेश दिखाई देगा -
Hi tutorialspoint
ध्यान दें कि tutorialspointहमारा उपयोगकर्ता नाम है। आपको अपने नाम के साथ ग्रीटिंग मिलेगा।
अगले अध्याय में, हम सीखेंगे कि एक JAX-WS (XML वेब सेवा के लिए Apache CXF API) परियोजना में CXF का उपयोग कैसे करें।
इस JAX-WS अनुप्रयोग में, हम Apache CXF-first दृष्टिकोण का उपयोग पहले के POJO अनुप्रयोग की तरह करेंगे। इसलिए पहले हम अपनी वेब सेवा के लिए एक इंटरफ़ेस बनाएंगे।
सेवा इंटरफ़ेस की घोषणा
जैसा कि पहले वाले मामले में, हम एक तुच्छ सेवा बनाएंगे जिसमें केवल एक इंटरफ़ेस विधि होगी जिसे अभिवादन कहा जाता है। सेवा इंटरफ़ेस के लिए कोड नीचे दिखाया गया है -
//HelloWorld.java
package com.tutorialspoint.cxf.jaxws.helloworld;
import javax.jws.WebService;
@WebService
public interface HelloWorld {
String greetings(String text);
}
हम एक के साथ इंटरफेस को एनोटेट करते हैं @WebServiceटैग। अगला, हम इस इंटरफ़ेस को लागू करेंगे।
वेब इंटरफेस को लागू करना
वेब इंटरफ़ेस का कार्यान्वयन यहाँ दिखाया गया है -
//HelloWorldImpl.java
package com.tutorialspoint.cxf.jaxws.helloworld;
public class HelloWorldImpl implements HelloWorld {
@Override
public String greetings(String name) {
return ("hi " + name);
}
}
अभिवादन विधि के साथ व्याख्या की जाती है @Overrideटैग। विधि कॉल करने वाले को "हाय" संदेश देती है।
अगला, हम सर्वर को विकसित करने के लिए कोड लिखेंगे।
सर्वर का विकास करना
POJO एप्लिकेशन के विपरीत, अब हम अपनी सेवा प्रकाशित करने के लिए CXF आपूर्ति किए गए समापन बिंदु वर्ग का उपयोग करके इंटरफ़ेस को अपघटित करेंगे। यह कोड की निम्नलिखित दो पंक्तियों में किया जाता है -
HelloWorld implementor = new HelloWorldImpl();
Endpoint.publish(
"http://localhost:9090/HelloServerPort",
implementor,
new LoggingFeature()
);
प्रकाशित विधि का पहला पैरामीटर उस URL को निर्दिष्ट करता है जिस पर हमारी सेवा ग्राहकों को उपलब्ध कराई जाएगी। दूसरा पैरामीटर हमारी सेवा के लिए कार्यान्वयन वर्ग को निर्दिष्ट करता है। सर्वर के लिए पूरा कोड नीचे दिखाया गया है -
//Server.java
package com.tutorialspoint.cxf.jaxws.helloworld;
import javax.xml.ws.Endpoint;
import org.apache.cxf.ext.logging.LoggingFeature;
public class Server {
public static void main(String[] args) throws Exception {
HelloWorld implementor = new HelloWorldImpl();
Endpoint.publish("http://localhost:9090/HelloServerPort",
implementor,
new LoggingFeature());
System.out.println("Server ready...");
Thread.sleep(5 * 60 * 1000);
System.out.println("Server exiting ...");
System.exit(0);
}
}
हमारे सर्वर को तैनात करने के लिए, आपको अपनी परियोजना में कुछ और संशोधन करने की आवश्यकता होगी जैसा कि नीचे सूचीबद्ध है।
सर्वर की तैनाती
अंत में, सर्वर एप्लिकेशन को तैनात करने के लिए, आपको अपने एप्लिकेशन को वेब एप्लिकेशन के रूप में सेटअप करने के लिए pom.xml में एक और संशोधन करना होगा। कोड जो आपको अपने में जोड़ना होगाpom.xml नीचे दिया गया है -
<profiles>
<profile>
<id>server</id>
<build>
<defaultGoal>test</defaultGoal>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<version>1.6.0</version>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
</goals>
<configuration>
<mainClass>
com.tutorialspoint.cxf.jaxws.helloworld.Server
</mainClass>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
</profiles>
इससे पहले कि आप एप्लिकेशन को तैनात करें, आपको अपनी परियोजना में दो और फाइलें जोड़ने की जरूरत है। ये नीचे स्क्रीनशॉट में दिखाए गए हैं -
ये फाइलें सीएक्सएफ मानक फाइलें हैं जो मानचित्रण को परिभाषित करती हैं CXFServlet। कोड के भीतरweb.xml फ़ाइल को आपके त्वरित संदर्भ के लिए यहाँ दिखाया गया है -
//Web.xml
<?xml version = "1.0" encoding = "UTF-8"??>
<web-app xmlns = "http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.5"
xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
<display-name>cxf</display-name>
<servlet>
<description>Apache CXF Endpoint</description>
<display-name>cxf</display-name>
<servlet-name>cxf</servlet-name>
<servlet-class>
org.apache.cxf.transport.servlet.CXFServlet
</servlet-class>
<load-on-startup>
1
</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>
cxf
</servlet-name>
<url-pattern>
/services/*
</url-pattern>
</servlet-mapping>
<session-config>
<session-timeout>60</session-timeout>
</session-config>
</web-app>
में cxf-servlet.xml,आप अपनी सेवा के समापन बिंदु के लिए गुणों की घोषणा करते हैं। यह नीचे दिए गए कोड स्निपेट में दिखाया गया है -
<beans ...>
<jaxws:endpoint xmlns:helloworld = "http://tutorialspoint.com/"
id = "helloHTTP"
address = "http://localhost:9090/HelloServerPort"
serviceName = "helloworld:HelloServiceService"
endpointName = "helloworld:HelloServicePort">
</jaxws:endpoint>
</beans>
यहां हम अपने सर्विस एंडपॉइंट के लिए आईडी को परिभाषित करते हैं, जिस पते पर सेवा उपलब्ध होगी, सेवा का नाम और एंडपॉइंट का नाम। अब, आपको पता चला कि आपकी सेवा को सीएक्सएफ सर्वलेट द्वारा कैसे व्यवस्थित और संसाधित किया जाता है।
अंतिम pom.xml
pom.xmlकुछ और निर्भरता शामिल हैं। सभी निर्भरताओं का वर्णन करने के बजाय, हमने नीचे pom.xml का अंतिम संस्करण शामिल किया है -
<?xml version = "1.0" encoding = "UTF-8"??>
<project xmlns = "http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.tutorialspoint</groupId>
<artifactId>cxf-jaxws</artifactId>
<version>1.0</version>
<packaging>jar</packaging>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<profiles>
<profile>
<id>server</id>
<build>
<defaultGoal>test</defaultGoal>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<version>1.6.0</version>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
</goals>
<configuration>
<mainClass>
com.tutorialspoint.cxf.jaxws.helloworld.Server
</mainClass>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
<profile>
<id>client</id>
<build>
<defaultGoal>test</defaultGoal>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
<goals>
<configuration>
<mainClass>
com.tutorialspoint.cxf.jaxws.helloworld.Client
</mainClass>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
</profiles>
<dependencies>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-frontend-jaxws</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-features-logging</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http-jetty</artifactId>
<version>3.3.0</version>
</dependency>
</dependencies>
</project>
ध्यान दें कि इसमें क्लाइंट के निर्माण के लिए एक प्रोफ़ाइल भी शामिल है जिसे हम इस ट्यूटोरियल के बाद के खंडों में सीखेंगे।
HelloWorld सेवा चला रहा है
अब, आप वेब ऐप चलाने के लिए तैयार हैं। कमांड विंडो में, निम्न कमांड का उपयोग करके बिल्ड स्क्रिप्ट चलाएँ।
mvn clean install
mvn -Pserver
आपको कंसोल पर निम्न संदेश दिखाई देगा -
INFO: Setting the server's publish address to be http://localhost:9090/HelloServerPort
Server ready…
पहले की तरह, आप अपने ब्राउज़र में सर्वर URL खोलकर सर्वर का परीक्षण कर सकते हैं।
जैसा कि हमने किसी भी ऑपरेशन को निर्दिष्ट नहीं किया है, केवल एक गलती संदेश हमारे आवेदन द्वारा ब्राउज़र को वापस कर दिया गया है।
अब, जोड़ने का प्रयास करें ?wsdl अपने URL पर जाएं और आपको निम्न आउटपुट दिखाई देंगे -
इसलिए हमारा सर्वर एप्लिकेशन उम्मीद के मुताबिक चल रहा है। आप SOAP क्लाइंट का उपयोग कर सकते हैं जैसे किPostman आगे आपकी सेवा का परीक्षण करने के लिए पहले वर्णित है।
अगले भाग में, हम सीखेंगे कि हमारी सेवा का उपयोग करने वाले ग्राहक कैसे लिखें।
ग्राहक का विकास करना
एक CXF अनुप्रयोग में क्लाइंट लिखना सर्वर लिखने जैसा ही तुच्छ है। यहाँ ग्राहक के लिए पूरा कोड है -
//Client.java
package com.tutorialspoint.cxf.jaxws.helloworld;
import javax.xml.namespace.QName;
import javax.xml.ws.Service;
import javax.xml.ws.soap.SOAPBinding;
public final class Client {
private static final QName SERVICE_NAME
= new QName("http://helloworld.jaxws.cxf.tutorialspoint.com/",
"HelloWorld");
private static final QName PORT_NAME
= new QName("http://helloworld.jaxws.cxf.tutorialspoint.com/",
"HelloWorldPort");
private Client() {
}
public static void main(String[] args) throws Exception {
Service service = Service.create(SERVICE_NAME);
System.out.println("service created");
String endpointAddress = "http://localhost:9090/HelloServerPort";
service.addPort(PORT_NAME, SOAPBinding.SOAP11HTTP_BINDING,
endpointAddress);
HelloWorld hw = service.getPort(HelloWorld.class);
System.out.println(hw.greetings("World"));
}
}
यहां, हम आपूर्ति की गई सीएक्सएफ का उपयोग करते हैं Serviceज्ञात सेवा के लिए बाध्य करने के लिए वर्ग। हम कहते हैंcreate पर विधि Serviceसेवा का एक उदाहरण प्राप्त करने के लिए कक्षा। हमने कॉल करके ज्ञात पोर्ट सेट किया हैaddPort पर विधि service उदाहरण।
अब, हम सेवा का उपभोग करने के लिए तैयार हैं, जिसे हम पहले कॉल करके सेवा इंटरफ़ेस प्राप्त करते हैं getPort पर विधि serviceउदाहरण। अंत में, हम अपने फोन करते हैंgreetings कंसोल पर बधाई संदेश मुद्रित करने की विधि।
अब, जैसा कि आपने Apache CXF-First दृष्टिकोण का उपयोग करके CXF की मूल बातें सीख ली हैं, अब आप सीखेंगे कि हमारे अगले अध्याय में WSDL-First दृष्टिकोण के साथ CXF का उपयोग कैसे करें।
CXF-POJO अनुप्रयोग है कि आप ग्राहक और सर्वर के बीच एक बहुत तंग युग्मन में परिणाम विकसित किया है। सेवा इंटरफ़ेस के लिए सीधी पहुँच देने से गंभीर सुरक्षा खतरे भी हो सकते हैं। इस प्रकार, क्लाइंट और सर्वर के बीच डिकम्प्लिंग आमतौर पर वांछित होता है, जिसे WSDL (वेब सेवा विवरण भाषा) का उपयोग करके हासिल किया जाता है।
हम WSDL दस्तावेज़ में वेब सेवा इंटरफ़ेस लिखते हैं जो XML- आधारित है। हम इस WSDL को अपाचे सीएक्सएफ इंटरफेस में मैप करने के लिए एक टूल का उपयोग करेंगे जो तब हमारे क्लाइंट और सर्वर एप्लिकेशन द्वारा कार्यान्वित और उपयोग किया जाता है। डीकोडिंग प्रदान करने के लिए, डब्ल्यूएसडीएल के साथ शुरू करना एक पसंदीदा तरीका है। इसके लिए, आपको सबसे पहले एक नई भाषा सीखने की जरूरत है - डब्ल्यूएसडीएल। डब्लूएसडीएल को लिखने के लिए एक सावधानीपूर्वक दृष्टिकोण की आवश्यकता होती है और यह बेहतर होगा कि आप इस पर काम शुरू करने से पहले इस पर कुछ समझ हासिल कर सकें।
इस पाठ में, हम एक WSDL दस्तावेज़ में एक वेब सेवा इंटरफ़ेस को परिभाषित करके शुरू करेंगे। हम सीखेंगे कि डब्ल्यूएसडीएल के साथ शुरू होने वाले सर्वर और क्लाइंट अनुप्रयोगों दोनों को बनाने के लिए सीएक्सएफ का उपयोग कैसे करें। हम सीएक्सएफ के उपयोग पर ध्यान बनाए रखने के लिए आवेदन को सरल रखेंगे। सर्वर एप्लिकेशन बनने के बाद हम इसे बिल्ट-इन CXF क्लास का उपयोग करके वांछित URL पर प्रकाशित करेंगे।
सबसे पहले, डब्ल्यूएसडीएल का वर्णन करें जिसका हम उपयोग करने जा रहे हैं।
नमस्ते के लिए WSDL
Webservice जिसे हम लागू करने जा रहे हैं, उसमें एक एकल वेबमिथोड कहा जाएगा greetings वह स्वीकार करता है stringउपयोगकर्ता नाम को बधाई संदेश भेजने के बाद उपयोगकर्ता नाम रखने वाला पैरामीटर और कॉल करने वाले को एक स्ट्रिंग संदेश देता है। पूरा wsdl नीचे दिखाया गया है -
//Hello.wsdl
<?xml version = "1.0" encoding = "UTF-8"?>
<wsdl:definitions xmlns:soap = "http://schemas.xmlsoap.org/wsdl/soap/"
xmlns:tns = "http://helloworld.tutorialspoint.com/"
xmlns:wsdl = "http://schemas.xmlsoap.org/wsdl/"
xmlns:xsd = "http://www.w3.org/2001/XMLSchema"
name = "HelloWorld"
targetNamespace = "http://helloworld.tutorialspoint.com/">
<wsdl:types>
<xsd:schema attributeFormDefault = "unqualified"
elementFormDefault = "qualified"
targetNamespace = "http://helloworld.tutorialspoint.com/">
<xsd:element name = "greetings" type = "tns:greetings"/>
<xsd:complexType name = "greetings">
<xsd:sequence>
<xsd:element minOccurs = "0" name = "arg0" type = "xsd:string"/>
</xsd:sequence>
</xsd:complexType>
<xsd:element name = "greetingsResponse"
type = "tns:greetingsResponse"/>
<xsd:complexType name = "greetingsResponse">
<xsd:sequence>
<xsd:element minOccurs = "0" name = "return" type = "xsd:string"/>
</xsd:sequence>
</xsd:complexType>
</xsd:schema>
</wsdl:types>
<wsdl:message name = "greetings">
<wsdl:part element = "tns:greetings" name = "parameters"> </wsdl:part>
</wsdl:message>
<wsdl:message name = "greetingsResponse">
<wsdl:part element = "tns:greetingsResponse" name = "parameters"> </wsdl:part>
</wsdl:message>
<wsdl:portType name = "HelloWorldPortType">
<wsdl:operation name = "greetings">
<wsdl:input message = "tns:greetings" name = "greetings"> </wsdl:input>
<wsdl:output message = "tns:greetingsResponse" name = "greetingsResponse">
</wsdl:output>
</wsdl:operation>
</wsdl:portType>
<wsdl:binding name = "HelloWorldSoapBinding" type = "tns:HelloWorldPortType">
<soap:binding style = "document"
transport = "http://schemas.xmlsoap.org/soap/http"/>
<wsdl:operation name = "greetings">
<soap:operation soapAction = "" style = "document"/>
<wsdl:input name = "greetings"></wsdl:input>
<wsdl:output name = "greetingsResponse">
<soap:body use = "literal"/>
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:service name = "HelloWorldService">
<wsdl:port binding = "tns:HelloWorldSoapBinding" name = "HelloWorldPort">
<soap:address location = "http://localhost:9090/HelloServerPort"/>
</wsdl:port>
</wsdl:service>
</wsdl:definitions>
ध्यान दें कि एक वाक्यात्मक रूप से सही wsdl लिखना हमेशा डेवलपर्स के लिए एक चुनौती रहा है; कई उपकरण हैं और एक wsdl बनाने के लिए ऑनलाइन संपादक उपलब्ध हैं। ये संपादक उन संदेशों के नाम पूछते हैं, जिन्हें आप उन मापदंडों के साथ लागू करना चाहते हैं, जिन्हें आप किसी संदेश में पास करना चाहते हैं और वापसी संदेश का प्रकार जिसे आप अपने ग्राहक को प्राप्त करना चाहते हैं। यदि आप wsdl सिंटैक्स जानते हैं, तो आप संपूर्ण दस्तावेज़ को कोड कर सकते हैं या अपने स्वयं के बनाने के लिए संपादकों में से एक का उपयोग कर सकते हैं।
उपरोक्त wsdl में, हमने एकल संदेश को परिभाषित किया है greetings। संदेश सेवा के लिए दिया जाता हैHelloWorldService वह चल रहा है http://localhost:9090/HelloServerPort.
इसके साथ, हम अब सर्वर विकास के लिए आगे बढ़ेंगे। सर्वर को विकसित करने से पहले, हमें अपनी वेब सेवा के लिए अपाचे सीएक्सएफ इंटरफेस उत्पन्न करना होगा। यह दिए गए wsdl से किया जाना है। ऐसा करने के लिए, आप नामक एक उपकरण का उपयोग करते हैंwsdl2java।
Wsdl2java प्लगइन
जैसा कि हम प्रोजेक्ट बनाने के लिए मावेन का उपयोग कर रहे हैं, आपको निम्न प्लगइन को इसमें जोड़ना होगा pom.xml फ़ाइल।
<plugins>
<plugin>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-codegen-plugin</artifactId>
<version>3.3.0</version>
<executions>
<execution>
<id>generate-sources</id>
<phase>generate-sources</phase>
<configuration>
<wsdlOptions>
<wsdlOption>
<wsdl>src/main/resources/hello.wsdl</wsdl>
<faultSerialVersionUID> 1 </faultSerialVersionUID>
</wsdlOption>
</wsdlOptions>
</configuration>
<goals>
<goal>wsdl2java</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
ध्यान दें कि हम का स्थान निर्दिष्ट करते हैं wsdl के रूप में दर्ज करें src/main/resources/Hello.wsdl। आपको यह सुनिश्चित करना होगा कि आप अपनी परियोजना के लिए एक उपयुक्त निर्देशिका संरचना बनाएं और पहले दिखाए गए को जोड़ देंhello.wsdl निर्दिष्ट फ़ोल्डर में फ़ाइल।
wsdl2javaप्लगइन इस wsdl को संकलित करेगा और पूर्व-परिभाषित फ़ोल्डर में Apache CXF कक्षाएं बनाएगा। पूरा प्रोजेक्ट ढांचा आपके तैयार संदर्भ के लिए यहां दिखाया गया है।
अब, आप का उपयोग कर एक सर्वर बनाने के लिए तैयार हैं wsdl2javaउत्पन्न कक्षाएं। Wsdl2java ने जो कक्षाएं बनाई हैं, उन्हें नीचे दिए गए आंकड़े में दिखाया गया है -
सेवा इंटरफ़ेस जनरेट किया गया
उत्पन्न कक्षाओं की सूची में, आपने देखा होगा कि उनमें से एक अपाचे सीएक्सएफ इंटरफ़ेस है - यह है HelloWorldPortType.java। अपने कोड संपादक में इस फ़ाइल की जाँच करें। फ़ाइल सामग्री को आपके तैयार संदर्भ के लिए यहां दिखाया गया है -
//HelloWorldPortType.java
package com.tutorialspoint.helloworld;
import javax.jws.WebMethod;
import javax.jws.WebParam;
import javax.jws.WebResult;
import javax.jws.WebService;
import javax.xml.bind.annotation.XmlSeeAlso;
import javax.xml.ws.RequestWrapper;
import javax.xml.ws.ResponseWrapper;
/**
* This class was generated by Apache CXF 3.3.0
* 2019-02-11T12:05:55.220+05:30
* Generated source version: 3.3.0
*
*/
@WebService(targetNamespace = "http://helloworld.tutorialspoint.com/",
name = "HelloWorldPortType")
@XmlSeeAlso({ObjectFactory.class})
public interface HelloWorldPortType {
@WebMethod
@RequestWrapper(localName = "greetings", targetNamespace =
"http://helloworld.tutorialspoint.com/", className =
"com.tutorialspoint.helloworld.Greetings")
@ResponseWrapper(localName = "greetingsResponse", targetNamespace =
"http://helloworld.tutorialspoint.com/", className =
"com.tutorialspoint.helloworld.GreetingsResponse")
@WebResult(name = "return", targetNamespace =
"http://helloworld.tutorialspoint.com/")
public java.lang.String greetings(
@WebParam(name = "arg0", targetNamespace =
"http://helloworld.tutorialspoint.com/")
java.lang.String arg0
);
}
ध्यान दें कि इंटरफ़ेस में एक विधि कहा जाता है greetings। यह हमारे wsdl में एक संदेश प्रकार था। wsdl2javaउपकरण ने इस विधि को जनरेट किए गए इंटरफ़ेस में जोड़ा है। अब, आप समझ सकते हैं कि आप अपने wsdl में जो भी संदेश लिखते हैं, इंटरफ़ेस में एक संबंधित विधि उत्पन्न होगी।
अब, आपका कार्य इन सभी तरीकों को लागू करना होगा जो आपने अपने wsdl में परिभाषित विभिन्न संदेशों के अनुरूप हैं। ध्यान दें कि Apache CXF-First के पहले उदाहरण में, हमने अपनी वेब सेवा के लिए Apache CXF इंटरफ़ेस के साथ शुरुआत की थी। इस मामले में, अपाचे सीएक्सएफ इंटरफेस को wsdl से बनाया गया है।
सेवा इंटरफ़ेस लागू करना
सेवा इंटरफ़ेस का कार्यान्वयन तुच्छ है। पूर्ण कार्यान्वयन नीचे दी गई सूची में दिखाया गया है -
//HelloWorldImpl.java
package com.tutorialspoint.helloworld;
public class HelloWorldImpl implements HelloWorldPortType {
@Override
public String greetings(String name) {
return ("hi " + name);
}
}
कोड एकमात्र इंटरफ़ेस विधि को लागू करता है जिसे कहा जाता है greetings। विधि के एक पैरामीटर लेता हैstring प्रकार, इसे करने के लिए एक "हाय" संदेश प्रस्तुत करता है और कॉलर को परिणामी स्ट्रिंग लौटाता है।
अगला, हम सर्वर एप्लिकेशन लिखेंगे।
सर्वर का विकास करना
सर्वर एप्लिकेशन विकसित करना एक बार फिर तुच्छ है। यहां, हम आपूर्ति की गई सीएक्सएफ का उपयोग करेंगेEndpointहमारी सेवा प्रकाशित करने के लिए कक्षा। यह कोड की निम्नलिखित दो पंक्तियों में किया जाता है -
HelloWorldPortType implementor = new HelloWorldImpl();
Endpoint.publish("http://localhost:9090/HelloServerPort",
implementor,
new LoggingFeature());
सबसे पहले, हम अपने सेवा कार्यान्वयनकर्ता वर्ग की एक वस्तु बनाते हैं - HelloWorldImpl। फिर, हम इस संदर्भ को दूसरे पैरामीटर के रूप में पास करते हैंpublishतरीका। पहला पैरामीटर वह पता है जिसके लिए सेवा प्रकाशित की गई है - ग्राहक इस URL का उपयोग सेवा तक पहुंचने के लिए करेंगे। सर्वर एप्लिकेशन के लिए संपूर्ण स्रोत यहां दिया गया है -
//Server.java
package com.tutorialspoint.helloworld;
import javax.xml.ws.Endpoint;
import org.apache.cxf.ext.logging.LoggingFeature;
public class Server {
public static void main(String[] args) throws Exception {
HelloWorldPortType implementor = new HelloWorldImpl();
Endpoint.publish("http://localhost:9090/HelloServerPort",
implementor,
new LoggingFeature());
System.out.println("Server ready...");
Thread.sleep(5 * 60 * 1000);
System.out.println("Server exiting");
System.exit(0);
}
}
इस सर्वर वर्ग का निर्माण करने के लिए आपको अपने में एक बिल्ड प्रोफ़ाइल जोड़ना होगा pom.xml। यह नीचे दिखाया गया है -
<profile>
<id>server</id>
<build>
<defaultGoal>test</defaultGoal>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<version>1.6.0</version>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
</goals>
<configuration>
<mainClass>
com.tutorialspoint.helloworld.Server
</mainClass>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http-jetty</artifactId>
<version>3.3.0</version>
</dependency>
</dependencies>
</profile>
ध्यान दें कि पूरी तरह से योग्य नाम Serverवर्ग विन्यास में निर्दिष्ट है। इसके अलावा, निर्भरता टैग निर्दिष्ट करता है कि हम अपने सर्वर एप्लिकेशन को तैनात करने के लिए एम्बेडेड जेट्टी वेब सर्वर का उपयोग करेंगे।
सर्वर की तैनाती
अंत में, सर्वर एप्लिकेशन को तैनात करने के लिए, आपको अपने एप्लिकेशन को वेब एप्लिकेशन के रूप में सेटअप करने के लिए pom.xml में एक और संशोधन करना होगा। कोड जो आपको अपने में जोड़ना होगाpom.xml नीचे दिया गया है -
<defaultGoal>install</defaultGoal>
<pluginManagement>
<plugins>
<plugin>
<artifactId>maven-war-plugin</artifactId>
<version>3.2.2</version>
<configuration>
<webXml>src/main/webapp/WEB-INF/web.xml</webXml>
<webResources>
<resource>
<directory>src/main/resources</directory>
<targetPath>WEB-INF</targetPath>
<includes>
<include>*.wsdl</include>
</includes>
</resource>
</webResources>
</configuration>
</plugin>
</plugins>
</pluginManagement>
इससे पहले कि आप एप्लिकेशन को तैनात करें, आपको अपनी परियोजना में दो और फाइलें जोड़ने की जरूरत है। ये नीचे स्क्रीनशॉट में दिखाए गए हैं -
ये फाइलें सीएक्सएफ मानक फाइलें हैं जो मानचित्रण को परिभाषित करती हैं CXFServlet। कोड के भीतरweb.xml फ़ाइल को आपके त्वरित संदर्भ के लिए यहाँ दिखाया गया है -
//cxf-servlet.xml
<web-app xmlns = "http://java.sun.com/xml/ns/javaee"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" version="2.5"
xsi:schemaLocation = "http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
<display-name>cxf</display-name>
<servlet>
<description>Apache CXF Endpoint</description>
<display-name>cxf</display-name>
<servlet-name>cxf</servlet-name>
<servlet-class>
org.apache.cxf.transport.servlet.CXFServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>cxf</servlet-name>
<url-pattern>/services/*</url-pattern>
</servlet-mapping>
<session-config>
<session-timeout>60</session-timeout>
</session-config>
</web-app>
में cxf-servlet.xmlआप अपनी सेवा के समापन बिंदु के लिए गुणों की घोषणा करते हैं। यह नीचे दिए गए कोड स्निपेट में दिखाया गया है -
<beans ...>
<jaxws:endpoint xmlns:helloworld = "http://tutorialspoint.com/"
id="helloHTTP"
address = "http://localhost:9090/HelloServerPort"
serviceName = "helloworld:HelloServiceService"
endpointName = "helloworld:HelloServicePort">
</jaxws:endpoint>
</beans>
यहां हम अपने सर्विस एंडपॉइंट के लिए आईडी को परिभाषित करते हैं, जिस पते पर सेवा उपलब्ध होगी, सेवा का नाम और एंडपॉइंट का नाम। अब, आप समझते हैं कि सीएक्सएफ सर्वलेट द्वारा आपकी सेवा कैसे रूट और प्रोसेस की जाती है।
अंतिम pom.xml
pom.xmlकुछ और निर्भरता शामिल हैं। सभी निर्भरताओं का वर्णन करने के बजाय, हमने नीचे pom.xml का अंतिम संस्करण शामिल किया है -
<?xml version="1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.tutorialspoint</groupId>
<artifactId>cxf-wsdl</artifactId>
<version>1.0</version>
<packaging>jar</packaging>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<build>
<defaultGoal>install</defaultGoal>
<pluginManagement>
<plugins>
<plugin>
<artifactId>maven-war-plugin</artifactId>
<version>3.2.2</version>
<configuration>
<webXml>src/main/webapp/WEB-INF/web.xml</webXml>
<webResources>
<resource>
<directory>src/main/resources</directory>
<targetPath>WEB-INF</targetPath>
<includes>
<include>*.wsdl</include>
</includes>
</resource>
</webResources>
</configuration>
</plugin>
</plugins>
</pluginManagement>
<plugins>
<plugin>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-codegen-plugin</artifactId>
<version>3.3.0</version>
<executions>
<execution>
<id>generate-sources</id>
<phase>generate-sources</phase>
<configuration>
<wsdlOptions>
<wsdlOption>
<wsdl>src/main/resources/Hello.wsdl</wsdl>
<faultSerialVersionUID>1</faultSerialVersionUID>
</wsdlOption>
</wsdlOptions>
</configuration>
<goals>
<goal>wsdl2java</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<profiles>
<profile>
<id>server</id>
<build>
<defaultGoal>test</defaultGoal>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<version>1.6.0</version>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
</goals>
<configuration>
<mainClass>
com.tutorialspoint.helloworld.Server
</mainClass>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http-jetty</artifactId>
<version>3.3.0</version>
</dependency>
</dependencies>
</profile>
<profile>
<id>client</id>
<build>
<defaultGoal>test</defaultGoal>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
</goals>
<configuration>
<mainClass>
com.tutorialspoint.helloworld.Client
</mainClass>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
</profiles>
<dependencies>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-frontend-jaxws</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-management</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-features-metrics</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf.xjc-utils</groupId>
<artifactId>cxf-xjc-runtime</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-features-logging</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<version>1.6.0</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.8.0-beta2</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http-jetty</artifactId>
<version>3.3.0</version>
</dependency>
</dependencies>
</project>
ध्यान दें कि इसमें क्लाइंट के निर्माण के लिए एक प्रोफ़ाइल भी शामिल है जिसे हम बाद के अनुभागों में जल्द ही सीखेंगे।
HelloWorld सेवा चला रहा है
अब, आप वेब ऐप चलाने के लिए तैयार हैं। कमांड विंडो में, निम्न कमांड का उपयोग करके बिल्ड स्क्रिप्ट चलाएँ।
mvn clean install
यह आपके wsdl से उपयुक्त Apache CXF कक्षाएं उत्पन्न करेगा, अपने Apache CXF कक्षाओं को संकलित करेगा, सर्वर को एम्बेडेड जेट्टी सर्वर पर तैनात करेगा और आपका एप्लिकेशन चलाएगा।
आपको कंसोल पर निम्न संदेश दिखाई देगा -
INFO: Setting the server's publish address to be
http://localhost:9090/HelloServerPort
Server ready...
पहले की तरह, आप अपने ब्राउज़र में सर्वर URL खोलकर सर्वर का परीक्षण कर सकते हैं।
जैसा कि हमने किसी भी ऑपरेशन को निर्दिष्ट नहीं किया है, केवल एक गलती संदेश हमारे आवेदन द्वारा ब्राउज़र को वापस कर दिया गया है। अब, जोड़ने का प्रयास करें?wsdl अपने URL पर जाएं और आपको निम्न आउटपुट दिखाई देंगे -
इसलिए हमारा सर्वर एप्लिकेशन उम्मीद के मुताबिक चल रहा है। आप SOAP क्लाइंट का उपयोग कर सकते हैं जैसे किPostman आगे आपकी सेवा का परीक्षण करने के लिए पहले वर्णित है।
इस ट्यूटोरियल का अगला भाग एक क्लाइंट लिखना है जो हमारी सेवा का उपयोग करता है।
ग्राहक का विकास करना
एक सीएक्सएफ एप्लिकेशन में क्लाइंट लिखना उतना ही महत्वपूर्ण है जितना कि सर्वर लिखना। यहां ग्राहक के लिए पूरा कोड है जिसमें अनिवार्य रूप से केवल तीन लाइनें शामिल हैं, बाकी लाइनें उपयोगकर्ता को केवल सेवा की जानकारी प्रिंट करती हैं।
//Client.java
package com.tutorialspoint.helloworld;
public class Client {
public static void main(String[] args) throws Exception {
//Create the service client with its default wsdlurl
HelloWorldService helloServiceService = new HelloWorldService();
System.out.println("service: " +
helloServiceService.getServiceName());
System.out.println("wsdl location: " +
helloServiceService.getWSDLDocumentLocation());
HelloWorldPortType helloService =
helloServiceService.getHelloWorldPort();
System.out.println(helloService.greetings
(System.getProperty("user.name")));
}
}
यहां, हम बस अपनी सेवा का एक उदाहरण बनाते हैं HelloWorldServiceकॉल करके उसका पोर्ट प्राप्त करें getHelloWorldPort विधि, और फिर हमारे पास greetingsइसका संदेश दें। क्लाइंट चलाएँ और आपको निम्न आउटपुट दिखाई देगा -
service: {http://helloworld.tutorialspoint.com/}HelloWorldService
wsdl location: file:/Users/drsarang/Desktop/tutorialpoint/cxf-
wsdl/src/main/resources/Hello.wsdl
hi drsarang
अब तक आपने सीखा है कि अपाचे CXF-First और WSDL-First आर्किटेक्चर के साथ CXF का उपयोग कैसे करें। Apache CXF-First दृष्टिकोण में, आपने एक POJO का उपयोग किया हैServerFactoryBeanसर्वर बनाने के लिए सीएक्सएफ लाइब्रेरी से क्लास। आपके द्वारा उपयोग किए जाने वाले ग्राहक बनाने के लिएClientProxyFactoryBeanसीएक्सएफ लाइब्रेरी से क्लास। WSDL-First दृष्टिकोण में, आपने उपयोग कियाEndpointवांछित URL और निर्दिष्ट कार्यान्वयनकर्ता पर सेवा प्रकाशित करने के लिए क्लास। अब आप विभिन्न प्रोटोकॉल और ट्रांसपोर्ट को एकीकृत करने के लिए इन तकनीकों का विस्तार कर सकते हैं।
इस अध्याय में आगे बढ़ने से पहले, हम मानते हैं कि आप जावा में एक RESTful वेब सेवा लिखना जानते हैं। मैं आपको दिखाता हूं कि इस JAX-RS (रैस्टफुल वेब सेवाओं के लिए जावा एपीआई) के शीर्ष पर सीएक्सएफ का उपयोग कैसे करें। हम एक वेब सेवा बनाएंगे जो नवीनतम फिल्मों की सूची बनाए रखेगी। जब उपयोगकर्ता एक फिल्म का अनुरोध करता है, तो वह अपने अनुरोध में फिल्म आईडी निर्दिष्ट करता है, सर्वर फिल्म का पता लगाएगा और इसे क्लाइंट को वापस कर देगा। हमारे तुच्छ मामले में, हम केवल क्लाइंट को फिल्म का नाम देंगे न कि वास्तविक बाइनरी MP4 फ़ाइल। तो चलिए एक JAX-RS एप्लिकेशन बनाना शुरू करते हैं।
फिल्म तत्व की घोषणा
हम किसी मूवी के लिए आईडी और नाम को स्टोर करने के लिए मूवी नामक एक्सएमएल रूट एलिमेंट घोषित करेंगे। तत्व मूवी.जवा नामक एक फ़ाइल में घोषित किया गया है। फ़ाइल की सामग्री यहाँ दिखाई गई है -
//Movie.java
package com.tutorialspoint.cxf.jaxrs.movie;
import javax.xml.bind.annotation.XmlRootElement;
@XmlRootElement(name = "Movie")
public class Movie {
private long id;
private String name;
public long getId() {
return id;
}
public void setId(long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
के उपयोग पर ध्यान दें XmlRootElement के लिए XML तत्व घोषित करने के लिए टैग Movieटैग। अगला, हम एक ऐसी सेवा बनाएंगे जो अपने डेटाबेस में फिल्मों की सूची रखती है।
मूवी सर्विस डेटाबेस बनाना
फिल्मों की सूची को संग्रहीत करने के लिए हम जावा आपूर्ति का उपयोग करते हैं Mapजो कुंजी-मूल्य जोड़े को संग्रहीत करता है। यदि सूची बड़ी है, तो आप एक बाहरी डेटाबेस संग्रहण का उपयोग करेंगे, जिसे प्रबंधित करना भी आसान होगा। हमारे तुच्छ मामले में, हम अपने डेटाबेस में केवल पाँच फिल्में संग्रहीत करेंगे। मूवी सर्विस क्लास के लिए कोड नीचे दिया गया है -
//MovieService.java
package com.tutorialspoint.cxf.jaxrs.movie;
import java.util.HashMap;
import java.util.Map;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
@Path("/movieservice/")
@Produces("text/xml")
public class MovieService {
long currentId = 123;
Map<Long, Movie> movies = new HashMap<>();
public MovieService() {
init();
}
@GET
@Path("/movie/{id}/")
public Movie getMovie(@PathParam("id") String id) {
long idNumber = Long.parseLong(id);
return movies.get(idNumber);
}
final void init() {
Movie c1 = new Movie();
c1.setName("Aquaman");
c1.setId(1001);
movies.put(c1.getId(), c1);
Movie c2 = new Movie();
c2.setName("Mission Imposssible");
c2.setId(1002);
movies.put(c2.getId(), c2);
Movie c3 = new Movie();
c3.setName("Black Panther");
c3.setId(1003);
movies.put(c3.getId(), c3);
Movie c4 = new Movie();
c4.setName("A Star is Born");
c4.setId(1004);
movies.put(c4.getId(), c4);
Movie c5 = new Movie();
c5.setName("The Meg");
c5.setId(1005);
movies.put(c5.getId(), c5);
}
}
ध्यान दें कि हम अपनी फिल्म सेवा और इसके वापसी प्रकार के लिए URL पथ निर्दिष्ट करने के लिए निम्नलिखित दो एनोटेशन का उपयोग करते हैं -
@Path("/movieservice/")
@Produces("text/xml")
हम निम्न के लिए GET अनुरोध के लिए URL निर्दिष्ट करने के लिए @GET और @Path एनोटेशन का उपयोग करते हैं -
@GET
@Path("/movie/{id}/")
मूवी डेटाबेस में ही इनिट विधि शुरू की जाती है, जहाँ हम डेटाबेस में पाँच मूवी आइटम जोड़ते हैं।
हमारा अगला काम सर्वर एप्लिकेशन लिखना है।
सर्वर का विकास करना
सर्वर बनाने के लिए, हम आपूर्ति की गई सीएक्सएफ का उपयोग करते हैं JAXRSServerFactoryBean कक्षा।
JAXRSServerFactoryBean factory = new JAXRSServerFactoryBean();
हम इसके संसाधन वर्गों को कॉल करके सेट करते हैं setResourceClasses तरीका।
factory.setResourceClasses(Movie.class);
factory.setResourceClasses(MovieService.class);
हम सेवा प्रदाता को कॉल करके सेट करते हैं setResourceProvider तरीका।
factory.setResourceProvider(MovieService.class,
new SingletonResourceProvider(new MovieService()));
हमने वांछित सेट किया publish कॉल करके पता aetAddress विधि -
factory.setAddress("http://localhost:9000/");
अंत में, हम सर्वर को बनाने की विधि पर कॉल करके प्रकाशित करते हैं factory उदाहरण।
factory.create();
सर्वर एप्लिकेशन के लिए पूरा कोड नीचे दिया गया है -
//Server.java
package com.tutorialspoint.cxf.jaxrs.movie;
import org.apache.cxf.jaxrs.JAXRSServerFactoryBean;
import org.apache.cxf.jaxrs.lifecycle.SingletonResourceProvider;
public class Server {
public static void main(String[] args) throws Exception {
JAXRSServerFactoryBean factory = new JAXRSServerFactoryBean();
factory.setResourceClasses(Movie.class);
factory.setResourceClasses(MovieService.class);
factory.setResourceProvider(MovieService.class,
new SingletonResourceProvider(new MovieService()));
factory.setAddress("http://localhost:9000/");
factory.create();
System.out.println("Server ready...");
Thread.sleep(5 * 60 * 1000);
System.out.println("Server exiting ...");
System.exit(0);
}
}
अंतिम pom.xml
यहाँ हमने नीचे pom.xml का अंतिम संस्करण शामिल किया है -
<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.tutorialspoint</groupId>
<artifactId>cxf-jaxrs</artifactId>
<version>1.0</version>
<packaging>jar</packaging>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<profiles>
<profile>
<id>server</id>
<build>
<defaultGoal>test</defaultGoal>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<version>1.6.0</version>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
</goals>
<configuration>
<mainClass>
com.tutorialspoint.cxf.jaxrs.movie.Server
</mainClass>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http-jetty</artifactId>
<version>3.3.0</version>
</dependency>
</dependencies>
</profile>
<profile>
<id>client</id>
<build>
<defaultGoal>test</defaultGoal>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
</goals>
<configuration>
<mainClass>
com.tutorialspoint.cxf.jaxrs.movie.Client
</mainClass>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
</profiles>
<dependencies>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http-jetty</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-frontend-jaxrs</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>jakarta.ws.rs</groupId>
<artifactId>jakarta.ws.rs-api</artifactId>
<version>2.1.5</version>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.7</version>
</dependency>
</dependencies>
</project>
ग्राहक का विकास करना
RS क्लाइंट लिखना तुच्छ है। हम बस एक URL ऑब्जेक्ट बनाते हैं और उसकी स्ट्रीम खोलते हैं। हम एक स्थानीय स्ट्रीम में इनपुट स्ट्रीम की सामग्री की प्रतिलिपि बनाने के लिए CXF आपूर्ति किए गए IOUtils वर्ग का उपयोग करते हैं।
URL url = new URL("http://localhost:9000/movieservice/movie/1002");
try (InputStream instream = url.openStream();
CachedOutputStream outstream = new CachedOutputStream()) {
IOUtils.copy(instream, outstream);
}
ग्राहक आवेदन के लिए पूरा कोड नीचे दिया गया है -
//Client.java
package com.tutorialspoint.cxf.jaxrs.movie;
import java.io.InputStream;
import java.net.URL;
import org.apache.cxf.helpers.IOUtils;
import org.apache.cxf.io.CachedOutputStream;
public class Client {
public static void main(String[] args) throws Exception {
URL url = new URL("http://localhost:9000/movieservice/movie/1002");
try (InputStream instream = url.openStream();
CachedOutputStream outstream = new CachedOutputStream()) {
IOUtils.copy(instream, outstream);
String str = outstream.getOut().toString();
System.out.println(str);
}
}
}
परीक्षण JAX-RS अनुप्रयोग
कमांड-लाइन विंडो में निम्नलिखित कमांड का उपयोग करके सर्वर को चलाएं -
mvn -Pserver
अब, आप कंसोल पर निम्न संदेश देखेंगे -
INFO: Setting the server's publish address to be http://localhost:9000
अब, अपना ब्राउज़र खोलें और निम्न URL टाइप करें -
http://localhost:9000/movieservice/movie/1002
आप ब्राउज़र विंडो में निम्न देखेंगे।
आप एक जावा क्लाइंट एप्लिकेशन का उपयोग करके सेवा शुरू कर सकते हैं जिसे हमने एक अलग कमांड-लाइन विंडो में निम्न कमांड चलाकर विकसित किया है।
mvn -Pclient
आप निम्न आउटपुट देखेंगे -
<?xml version="1.0" encoding = "UTF-8" standalone="yes"?>
<Movie><id>1002</id><name>Mission Imposssible</name></Movie>
सीएक्सएफ के नमूने जेएक्स-आरएस के साथ सीएक्सएफ का उपयोग करने के कई उदाहरण प्रदान करते हैं। इच्छुक पाठकों को इन नमूनों का अध्ययन करने के लिए प्रोत्साहित किया जाता है।
जैसा कि पहले उल्लेख किया गया है, आप जेएमएस परिवहन के साथ सीएक्सएफ का उपयोग कर सकते हैं। इस स्थिति में, क्लाइंट एक ज्ञात मैसेजिंग सर्वर को जेएमएस संदेश भेजेगा। आने वाले संदेशों के लिए हमारा सर्वर एप्लिकेशन मैसेजिंग सर्वर को लगातार सुन रहा है। जब संदेश आता है, तो यह संदेश को संसाधित करता है, क्लाइंट अनुरोध को निष्पादित करता है और ग्राहक को एक अन्य संदेश के रूप में प्रतिक्रिया भेजता है।
पहले की तरह, हम पहले एक नमूना सर्वर अनुप्रयोग बनाएंगे जो एक विलक्षण वेब विधि प्रदान करता है जिसे कहा जाता है sayHi।
सेवा इंटरफ़ेस बनाना
हमारे लिए सेवा इंटरफ़ेस HelloWorld सेवा यहाँ दिखाई गई है -
//HelloWorld.java
package com.tutorialspoint.service;
import javax.jws.WebMethod;
import javax.jws.WebParam;
import javax.jws.WebService;
@WebService
public interface HelloWorld {
@WebMethod
String sayHi(@WebParam(name = "name") String name);
}
लागू करने वाली सेवा
सेवा इंटरफ़ेस का कार्यान्वयन निम्नानुसार परिभाषित किया गया है -
//HelloWorldImpl.java
package com.tutorialspoint.service.impl;
import javax.jws.WebService;
import com.tutorialspoint.service.HelloWorld;
@WebService
public class HelloWorldImpl implements HelloWorld {
@Override
public String sayHi(String name) {
return "Hello " + name;
}
}
कार्यान्वयन केवल उपयोगकर्ता को एक हैलो संदेश देता है। जैसा कि आप देखते हैं, इंटरफ़ेस और इसका कार्यान्वयन इस ट्यूटोरियल में पहले की सभी परियोजनाओं के समान है, जिन्हें आपने अब तक अध्ययन किया है।
अब, सबसे महत्वपूर्ण बिंदु आता है जो एक सर्वर एप्लिकेशन बनाना है जो एक संदेश कतार बनाता है और आने वाले संदेशों को सुनता रहता है।
सर्वर बनाना
सर्वर एप्लिकेशन में, पहले हम एक बनाते हैं JMS अंत बिंदु इस प्रकार है -
private static final String JMS_ENDPOINT_URI =
"jms:queue:test.cxf.jmstransport.queue?timeToLive=1000"
+ "&jndiConnectionFactoryName=ConnectionFactory"
+ "&jndiInitialContextFactory"
+ "= org.apache.activemq.jndi.ActiveMQInitialContextFactory"
+ "&jndiURL = tcp://localhost:61616";
ध्यान दें कि हम एक निर्दिष्ट पोर्ट पर एक कतार स्थापित करते हैं जो एक निर्दिष्ट समय तक रहता है। अब हम इंस्टैंट करके एक मैसेजिंग सर्विस बनाते हैंorg.apache.activemq.broker.BrokerServiceकक्षा। यह एक सर्वर वर्ग हैActiveMQ मैसेजिंग सर्वर।
BrokerService broker = new BrokerService();
आप अपनी पसंद के किसी अन्य मैसेजिंग सर्वर को इसके अलावा इस्तेमाल कर सकते हैं ActiveMQ। अब हम इस सर्वर को एक वांछित यूआरआई से जोड़ते हैं।
broker.addConnector("tcp://localhost:61616");
हम आने वाले संदेशों के डेटा भंडारण के लिए निर्देशिका सेट करते हैं -
broker.setDataDirectory("target/activemq-data");
अंत में, हम प्रारंभ विधि का उपयोग कर सर्वर शुरू करते हैं -
broker.start();
अगला, हम अपनी सेवा बीन का एक उदाहरण बनाते हैं HelloWorld हमारे पहले के POJO एप्लिकेशन में उपयोग की जाने वाली सर्वर फ़ैक्टरी बीन क्लास का उपयोग करना -
Object implementor = new HelloWorldImpl();
JaxWsServerFactoryBean factory = new JaxWsServerFactoryBean();
factory.setServiceClass(HelloWorld.class);
अगला, हम कारखाने पर जेएमएस समापन बिंदु स्थापित करते हैं ताकि कारखाने आने वाले संदेशों को सुनते रहें -
factory.setTransportId
(JMSSpecConstants.SOAP_JMS_SPECIFICATION_TRANSPORTID);
factory.setAddress(JMS_ENDPOINT_URI);
अंत में, हम कारखाने में कार्यान्वयनकर्ता वर्ग स्थापित करते हैं और इसे चलाना शुरू करते हैं -
factory.setServiceBean(implementor);
factory.create();
इस बिंदु पर आपका सर्वर ऊपर और चल रहा है। ध्यान दें कि जब से हमने POJO एप्लिकेशन में फ़ैक्टरी बीन क्लास का उपयोग किया है, CXFervlet और web.xml फ़ाइल की आवश्यकता नहीं है।
पूरा सर्वर एप्लीकेशन कोड यहाँ दिखाया गया है -
//ServerJMS.java
package com.tutorialspoint.server;
import java.util.Collections;
import org.apache.cxf.ext.logging.LoggingFeature;
import org.apache.cxf.jaxws.JaxWsServerFactoryBean;
import org.apache.cxf.transport.jms.spec.JMSSpecConstants;
import com.tutorialspoint.service.HelloWorld;
import com.tutorialspoint.service.impl.HelloWorldImpl;
import org.apache.activemq.broker.BrokerService;
public final class ServerJMS {
private static final String JMS_ENDPOINT_URI =
"jms:queue:test.cxf.jmstransport.queue?timeToLive=1000"
+ "&jndiConnectionFactoryName=ConnectionFactory"
+ "&jndiInitialContextFactory"
+ "= org.apache.activemq.jndi.ActiveMQInitialContextFactory"
+ "&jndiURL = tcp://localhost:61616";
public static void main(String[] args) throws Exception {
BrokerService broker = new BrokerService();
broker.addConnector("tcp://localhost:61616");
broker.setDataDirectory("target/activemq-data");
broker.start();
Object implementor = new HelloWorldImpl();
JaxWsServerFactoryBean factory = new JaxWsServerFactoryBean();
factory.setServiceClass(HelloWorld.class);
factory.setTransportId
(JMSSpecConstants.SOAP_JMS_SPECIFICATION_TRANSPORTID);
factory.setAddress(JMS_ENDPOINT_URI);
factory.setServiceBean(implementor);
factory.setFeatures(Collections.singletonList(new LoggingFeature()));
factory.create();
System.out.println("Server ready...");
Thread.sleep(5 * 60 * 1000);
System.out.println("Server exiting");
System.exit(0);
}
}
निर्भरता को जोड़ना
सर्वर एप्लिकेशन जो हमने बनाया है वह ActiveMQ मैसेजिंग सर्वर का उपयोग करता है। इस प्रकार, आपको अपनी परियोजना में कुछ और निर्भरताएं जोड़ने की आवश्यकता होगी। आपके लिए अतिरिक्त आवश्यक निर्भरता समझने के लिए पूरी pom.xml फ़ाइल यहाँ दिखाई गई है।
<?xml version = "1.0" encoding = "UTF-8"?>
<project xmlns = "http://maven.apache.org/POM/4.0.0"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.tutorialspoint</groupId>
<artifactId>cxf-jms</artifactId>
<version>1.0</version>
<packaging>jar</packaging>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<profiles>
<profile>
<id>server</id>
<build>
<defaultGoal>test</defaultGoal>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<version>1.6.0</version>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
</goals>
<configuration>
<mainClass>
com.tutorialspoint.server.ServerJMS
</mainClass>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
<profile>
<id>client</id>
<build>
<defaultGoal>test</defaultGoal>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<executions>
<execution>
<phase>test</phase>
<goals>
<goal>java</goal>
</goals>
<configuration>
<mainClass>
com.tutorialspoint.client.ClientJMS
</mainClass>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
</profiles>
<dependencies>
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-broker</artifactId>
<version>5.15.8</version>
</dependency>
<dependency>
<groupId>org.apache.activemq</groupId>
<artifactId>activemq-kahadb-store</artifactId>
<version>5.15.8</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-frontend-jaxws</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-jms</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-features-logging</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-transports-http-jetty</artifactId>
<version>3.3.0</version>
</dependency>
</dependencies>
</project>
चल रहा सर्वर
सर्वर चलाना शुरू करने के लिए, पहले के मामलों की तरह, अपनी कमांड विंडो में निम्न कमांड टाइप करें -
mvn -Pserver
यह ActiveMQ संदेश सर्वर को प्रारंभ करेगा, मैसेजिंग कतार सेट करेगा और एक फ़ैक्टरी बीन बनाएगा जो इस कतार को सुनता रहता है।
हमारा अगला काम क्लाइंट एप्लिकेशन बनाना है।
ग्राहक बनाना
क्लाइंट एप्लिकेशन में, पहले हम JMS एंडपॉइंट को उसी तरह सेट करते हैं जैसे सर्वर एप्लिकेशन में उपयोग किया जाता है -
private static final String JMS_ENDPOINT_URI =
"jms:queue:test.cxf.jmstransport.queue?timeToLive=1000"
+ "&jndiConnectionFactoryName=ConnectionFactory"
+ "&jndiInitialContextFactory"
+ " = org.apache.activemq.jndi.ActiveMQInitialContextFactory"
+ "&jndiURL = tcp://localhost:61616";
हम POJO एप्लिकेशन के रूप में एक कारखाना बनाते हैं।
JaxWsProxyFactoryBean factory = new JaxWsProxyFactoryBean();
हम समापन बिंदु URI और कार्यान्वयनकर्ता वर्ग को निम्नानुसार सेट करते हैं -
factory.setTransportId (JMSSpecConstants.SOAP_JMS_SPECIFICATION_TRANSPORTID);
factory.setAddress (JMS_ENDPOINT_URI);
HelloWorld client = factory.create(HelloWorld.class);
अंत में, हम सेवा पद्धति को कॉल करते हैं और इसके परिणामी आउटपुट को प्रिंट करते हैं -
String reply = client.sayHi("TutorialsPoint");
System.out.println(reply);
पूरा क्लाइंट कोड नीचे दिया गया है -
// ClientJMS.java
package com.tutorialspoint.client;
import com.tutorialspoint.service.HelloWorld;
import org.apache.cxf.jaxws.JaxWsProxyFactoryBean;
import org.apache.cxf.transport.jms.spec.JMSSpecConstants;
public final class ClientJMS {
private static final String JMS_ENDPOINT_URI =
"jms:queue:test.cxf.jmstransport.queue?timeToLive=1000"
+ "&jndiConnectionFactoryName=ConnectionFactory"
+ "&jndiInitialContextFactory"
+ " = org.apache.activemq.jndi.ActiveMQInitialContextFactory"
+ "&jndiURL = tcp://localhost:61616";
public static void main(String[] args) throws Exception {
JaxWsProxyFactoryBean factory = new JaxWsProxyFactoryBean();
factory.setTransportId(JMSSpecConstants.SOAP_JMS_SPECIFICATION_TRANSPORTID);
factory.setAddress(JMS_ENDPOINT_URI);
HelloWorld client = factory.create(HelloWorld.class);
String reply = client.sayHi("TutorialsPoint");
System.out.println(reply);
System.exit(0);
}
}
अपाचे CXF - निष्कर्ष
सीएक्सएफ कई वेब प्रोटोकॉल को मिक्स-एन-मैच करने के लिए एक एकीकृत दृष्टिकोण प्रदान करता है और वेब एप्लिकेशन बनाने के लिए आज की दुनिया में मौजूद है। आपने सीखा कि कैसे एक पारंपरिक जावा इंटरफेस के साथ शुरू करने के लिए एक वेब एप्लिकेशन तैयार करना है जो सीएक्सएफ का उपयोग करता है। इसके बाद, आपने सीखा कि कैसे एक वेब एप्लिकेशन और उसके क्लाइंट को डब्ल्यूएसडीएल के साथ शुरू किया जाए।
WSDL आपके सेवा इंटरफ़ेस का XML प्रतिनिधित्व प्रदान करता है। आपने WSDL से Java इंटरफेस बनाने के लिए wsdl2java टूल का उपयोग किया और अंत में बनाए गए इंटरफेस का उपयोग करते हुए सर्वर और क्लाइंट दोनों को लिखा। ट्यूटोरियल ने संक्षेप में आपको अपने RESTful वेब सेवा एप्लिकेशन में CXF का उपयोग करने के लिए पेश किया। अंत में, हमने यह भी चर्चा की कि सीएक्सएफ का उपयोग जेएमएस के साथ कैसे किया जा सकता है। अब आप आगे के अध्ययन के लिए सीएक्सएफ-नमूनों का उल्लेख कर सकते हैं ।
Note - संपूर्ण परियोजना स्रोत कोड यहां से डाउनलोड किया जा सकता है।