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).