Spring - Наследование определения компонента
Определение bean-компонента может содержать много информации о конфигурации, включая аргументы конструктора, значения свойств и специфичную для контейнера информацию, такую как метод инициализации, имя статического фабричного метода и т. Д.
Определение дочернего компонента наследует данные конфигурации от родительского определения. Дочернее определение может переопределять некоторые значения или при необходимости добавлять другие.
Наследование определений Spring Bean не имеет ничего общего с наследованием классов Java, но концепция наследования такая же. Вы можете определить определение родительского bean-компонента как шаблон, а другие дочерние bean-компоненты могут наследовать требуемую конфигурацию от родительского bean-компонента.
Когда вы используете метаданные конфигурации на основе XML, вы указываете определение дочернего компонента с помощью parent атрибут, определяющий родительский компонент как значение этого атрибута.
пример
Разрешите нам иметь рабочую среду IDE Eclipse и предпринять следующие шаги для создания приложения Spring:
Шаги | Описание |
---|---|
1 | Создайте проект с именем SpringExample и создайте пакет com.tutorialspoint подsrc папку в созданном проекте. |
2 | Добавьте необходимые библиотеки Spring с помощью опции « Добавить внешние JAR», как описано в главе « Пример Spring Hello World» . |
3 | Создайте классы Java HelloWorld , HelloIndia и MainApp в пакете com.tutorialspoint . |
4 | Создайте файл конфигурации Beans Beans.xml подsrc папка. |
5 | Последним шагом является создание содержимого всех файлов Java и файла конфигурации компонента и запуск приложения, как описано ниже. |
Ниже приведен файл конфигурации Beans.xmlгде мы определили bean-компонент helloWorld, который имеет два свойства: message1 и message2 . Следующий bean-компонент "helloIndia" был определен как дочерний компонент "helloWorld" с помощьюparentатрибут. Дочерний bean-компонент наследует свойство message2 как есть, переопределяет свойство message1 и вводит еще одно свойство message3 .
<?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 = "helloWorld" class = "com.tutorialspoint.HelloWorld">
<property name = "message1" value = "Hello World!"/>
<property name = "message2" value = "Hello Second World!"/>
</bean>
<bean id ="helloIndia" class = "com.tutorialspoint.HelloIndia" parent = "helloWorld">
<property name = "message1" value = "Hello India!"/>
<property name = "message3" value = "Namaste India!"/>
</bean>
</beans>
Вот содержание HelloWorld.java файл -
package com.tutorialspoint;
public class HelloWorld {
private String message1;
private String message2;
public void setMessage1(String message){
this.message1 = message;
}
public void setMessage2(String message){
this.message2 = message;
}
public void getMessage1(){
System.out.println("World Message1 : " + message1);
}
public void getMessage2(){
System.out.println("World Message2 : " + message2);
}
}
Вот содержание HelloIndia.java файл -
package com.tutorialspoint;
public class HelloIndia {
private String message1;
private String message2;
private String message3;
public void setMessage1(String message){
this.message1 = message;
}
public void setMessage2(String message){
this.message2 = message;
}
public void setMessage3(String message){
this.message3 = message;
}
public void getMessage1(){
System.out.println("India Message1 : " + message1);
}
public void getMessage2(){
System.out.println("India Message2 : " + message2);
}
public void getMessage3(){
System.out.println("India Message3 : " + message3);
}
}
Ниже приводится содержание MainApp.java файл -
package com.tutorialspoint;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainApp {
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");
HelloWorld objA = (HelloWorld) context.getBean("helloWorld");
objA.getMessage1();
objA.getMessage2();
HelloIndia objB = (HelloIndia) context.getBean("helloIndia");
objB.getMessage1();
objB.getMessage2();
objB.getMessage3();
}
}
Когда вы закончите создание исходного файла и файла конфигурации bean-компонента, позвольте нам запустить приложение. Если с вашим приложением все в порядке, оно напечатает следующее сообщение -
World Message1 : Hello World!
World Message2 : Hello Second World!
India Message1 : Hello India!
India Message2 : Hello Second World!
India Message3 : Namaste India!
Если вы заметили здесь, мы не передавали message2 при создании bean-компонента "helloIndia", но оно было передано из-за наследования определения Bean-компонента.
Шаблон определения компонента
Вы можете создать шаблон определения компонента, который может использоваться другими определениями дочернего компонента без особых усилий. При определении шаблона определения компонента не следует указыватьclass атрибут и должен указать abstract атрибут и должен указать абстрактный атрибут со значением true как показано в следующем фрагменте кода -
<?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 = "beanTeamplate" abstract = "true">
<property name = "message1" value = "Hello World!"/>
<property name = "message2" value = "Hello Second World!"/>
<property name = "message3" value = "Namaste India!"/>
</bean>
<bean id = "helloIndia" class = "com.tutorialspoint.HelloIndia" parent = "beanTeamplate">
<property name = "message1" value = "Hello India!"/>
<property name = "message3" value = "Namaste India!"/>
</bean>
</beans>
Родительский компонент не может быть создан сам по себе, потому что он неполный, а также явно помечен как абстрактный . Когда определение является абстрактным, как это, его можно использовать только как определение чистого шаблонного компонента, которое служит родительским определением для дочерних определений.