Apache CXF с POJO
В этой главе вы узнаете, как разработать простое веб-приложение, отправляющее пользователю приветственное сообщение. Проект веб-службы использует модель WSDL . CXF позволяет скрыть эту модель WSDL, предоставляя простой интерфейс для сопоставления API CXF Apache с базовым WSDL.
В этом простейшем проекте интерфейс веб-службы будет напрямую открыт для клиента, и клиент будет использовать собственные API-интерфейсы Apache CXF для вызова веб-службы.
Сначала мы создадим веб-сервис. У каждой службы есть интерфейс, доступный клиенту. Мы можем написать этот интерфейс как простой интерфейс Apache CXF или как документ WSDL. В этом подходе Apache CXF-First мы будем предоставлять нашу службу через интерфейс Apache CXF.
Разработка веб-службы
Сервис, который мы собираемся создать в Интернете, будет иметь единственный веб-метод, называемый greetings. Метод требуетstringаргумент типа, в котором мы отправим имя пользователя. Служба отправит абоненту приветственное сообщение с полученным именем пользователя, включенным в сообщение.
Интерфейс веб-службы
Чтобы предоставить интерфейс нашей веб-службы, мы создадим интерфейс Apache CXF следующим образом:
//HelloWorld.java
package com.tutorialspoint.cxf.pojo;
public interface HelloWorld {
String greetings(String text);
}
В интерфейсе есть только один метод, называемый greetings. Сервер будет реализовывать этот интерфейс. В нашем тривиальном приложении этот интерфейс напрямую доступен клиенту. Как правило, в приложении веб-службы вы используете WSDL для описания интерфейса веб-службы. В этом простом приложении мы предоставим этот прямой интерфейс клиентскому разработчику. Затем клиент звонилgreetingsсообщение об объекте сервера. Итак, сначала давайте создадим веб-службу.
Реализация веб-сервиса
В HelloWorld интерфейс реализован в HelloWorldImpl Класс Apache CXF, как показано ниже -
//HelloWorldImpl.java
package com.tutorialspoint.cxf.pojo;
public class HelloWorldImpl implements HelloWorld {
@Override
public String greetings(String text) {
return "Hi " + text;
}
}
В greetings метод получает параметр string type, добавляет его к приветственному сообщению и возвращает полученную строку вызывающему.
Затем мы пишем серверное приложение для размещения HelloWorld оказание услуг.
Создание сервера
Серверное приложение состоит из двух частей -
Первая часть создает фабрику для нашего веб-сервиса, и
Вторая часть пишет main метод для его создания.
Сервер использует ServerFactoryBean класс, предоставляемый библиотеками CXF, чтобы раскрыть наши HelloWorldинтерфейс для удаленных клиентов. Таким образом, мы сначала создаем экземплярServerFactoryBean class, а затем установите его различные свойства -
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класс из библиотек CXF. Теперь мы должны включить эти библиотеки в наш проект, чтобы успешно скомпилироватьHelloServerкласс. Мы будем использоватьMaven для настройки зависимостей проекта.
Настройка проекта Maven
Чтобы создать проект Maven, введите следующую команду в окне командной строки. Обратите внимание, что мы протестировали это на компьютере Mac. Для установок Windows и Linux инструкции могут отличаться в некоторых местах.
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
По завершении команды maven вы найдете соответствующую структуру папок, созданную в вашей текущей папке вместе с файлом pom.xml.
Сгенерированная структура каталогов показана здесь -
Вы добавите зависимости CXF в pom.xmlа также скопируйте созданные выше файлы Apache CXF в соответствующую папку структуры, созданной maven. Для вашего удобства ниже мы предоставили файл 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-клиента. Здесь мы использовали Postman для тестирования нашего сервера.
Результат такой, как показано здесь -
Заметьте, что SOAP Requestбыл закодирован вручную. После отправки запроса сервер отправилSOAP Response сообщение, которое видно в нижней части снимка экрана.
Исходя из этого, вы можете понять, что CXF поддерживает использование протоколов SOAP как для запросов, так и для ответов, предоставляя вам единое представление о различных веб-технологиях, которые действительно существуют в современном мире. Это значительно упрощает разработку веб-приложений.
Наша следующая задача - создать клиента, который будет использовать созданный вами веб-сервис.
Создание клиента
В серверном приложении HelloWorld- это интерфейс, который предоставляет нашу веб-службу. Сама веб-служба просто предоставляет клиенту простое приветственное сообщение. Обычно интерфейс веб-службы открывается для внешнего мира с помощью WSDL (язык описания веб-служб). В этом тривиальном приложении мы предоставим клиенту доступ к нашему веб-сервису, напрямую открывая интерфейс сервиса, и этоHelloWorld.class.
Для этой цели CXF предоставляет фабричный класс под названием ClientProxyFactoryBean что позволяет нам присоединиться к желаемому интерфейсу к созданному экземпляру фабрики.
Сначала мы создаем экземпляр фабричного компонента следующим образом:
ClientProxyFactoryBean factory = new ClientProxyFactoryBean();
Мы называем setAddressв экземпляре фабричного компонента, чтобы установить URL-адрес, по которому может быть вызвана наша веб-служба. В нашем случае мы будем использовать 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это наше имя пользователя. Вы получите приветствие со своим именем.
В следующей главе мы узнаем, как использовать CXF в проекте JAX-WS (API Apache CXF для веб-служб XML).