Пользовательские события весной

Чтобы написать и опубликовать свои собственные события, необходимо выполнить ряд шагов. Следуйте инструкциям, приведенным в этой главе, чтобы писать, публиковать и обрабатывать пользовательские события Spring.

Шаги Описание
1 Создайте проект с именем SpringExample и создайте пакет com.tutorialspoint подsrcпапку в созданном проекте. Все классы будут созданы в этом пакете.
2 Добавьте необходимые библиотеки Spring с помощью опции « Добавить внешние JAR», как описано в главе « Пример Spring Hello World» .
3 Создайте класс события CustomEvent , расширивApplicationEvent. Этот класс должен определять конструктор по умолчанию, который должен наследовать конструктор от класса ApplicationEvent.
4 Как только ваш класс событий определен, вы можете опубликовать его из любого класса, скажем, EventClassPublisher, который реализует ApplicationEventPublisherAware . Вам также потребуется объявить этот класс в файле конфигурации XML как bean-компонент, чтобы контейнер мог идентифицировать bean-компонент как публикатора событий, поскольку он реализует интерфейс ApplicationEventPublisherAware.
5 Опубликованное событие может обрабатываться в классе, скажем, EventClassHandler, который реализует интерфейс ApplicationListener и реализует метод onApplicationEvent для настраиваемого события.
6 Создайте файл конфигурации beans Beans.xml подsrcпапка и класс MainApp, который будет работать как приложение Spring.
7 Последним шагом является создание содержимого всех файлов Java и файла конфигурации компонента и запуск приложения, как описано ниже.

Вот содержание CustomEvent.java файл

package com.tutorialspoint;

import org.springframework.context.ApplicationEvent;

public class CustomEvent extends ApplicationEvent{
   public CustomEvent(Object source) {
      super(source);
   }
   public String toString(){
      return "My Custom Event";
   }
}

Ниже приводится содержание CustomEventPublisher.java файл

package com.tutorialspoint;

import org.springframework.context.ApplicationEventPublisher;
import org.springframework.context.ApplicationEventPublisherAware;

public class CustomEventPublisher implements ApplicationEventPublisherAware {
   private ApplicationEventPublisher publisher;
   
   public void setApplicationEventPublisher (ApplicationEventPublisher publisher) {
      this.publisher = publisher;
   }
   public void publish() {
      CustomEvent ce = new CustomEvent(this);
      publisher.publishEvent(ce);
   }
}

Ниже приводится содержание CustomEventHandler.java файл

package com.tutorialspoint;

import org.springframework.context.ApplicationListener;

public class CustomEventHandler implements ApplicationListener<CustomEvent> {
   public void onApplicationEvent(CustomEvent event) {
      System.out.println(event.toString());
   }
}

Ниже приводится содержание MainApp.java файл

package com.tutorialspoint;

import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class MainApp {
   public static void main(String[] args) {
      ConfigurableApplicationContext context = 
         new ClassPathXmlApplicationContext("Beans.xml");
	  
      CustomEventPublisher cvp = 
         (CustomEventPublisher) context.getBean("customEventPublisher");
      
      cvp.publish();  
      cvp.publish();
   }
}

Ниже приведен файл конфигурации Beans.xml

<?xml version = "1.0" encoding = "UTF-8"?>

<beans xmlns = "http://www.springframework.org/schema/beans"
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://www.springframework.org/schema/beans
   http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">

   <bean id = "customEventHandler" class = "com.tutorialspoint.CustomEventHandler"/>
   <bean id = "customEventPublisher" class = "com.tutorialspoint.CustomEventPublisher"/>

</beans>

Когда вы закончите создание исходного файла и файла конфигурации bean-компонента, позвольте нам запустить приложение. Если с вашим приложением все в порядке, оно напечатает следующее сообщение -

y Custom Event
y Custom Event