Spring基于注解@Required配置

本文内容纲要:

- 基于注解的配置

- 下面是 Student.java 文件的内容:

- 下面是 MainApp.java 文件的内容:

- 下面是配置文件 Beans.xml: 文件的内容:  上面的头信息就省略了

- 运行结果:

基于注解的配置

从 Spring 2.5 开始就可以使用注解来配置依赖注入。而不是采用 XML 来描述一个 bean 连线,你可以使用相关类,方法或字段声明的注解,将 bean 配置移动到组件类本身。

在 XML 注入之前进行注解注入,因此后者的配置将通过两种方式的属性连线被前者重写。

注解连线在默认情况下在 Spring 容器中不打开。因此,在可以使用基于注解的连线之前,我们将需要在我们的 Spring 配置文件中启用它。所以如果你想在 Spring 应用程序中使用的任何注解,可以考虑到下面的配置文件。

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

2

3 <beans xmlns="http://www.springframework.org/schema/beans"

4 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

5 xmlns:context="http://www.springframework.org/schema/context"

6 xsi:schemaLocation="http://www.springframework.org/schema/beans

7 http://www.springframework.org/schema/beans/spring-beans-3.0.xsd

8 http://www.springframework.org/schema/context

9 http://www.springframework.org/schema/context/spring-context-3.0.xsd">

10

11 <context:annotation-config/>

12 <!-- bean definitions go here -->

13

14 </beans>

@Required 注释应用于 bean 属性的 setter 方法,它表明受影响的 bean 属性在配置时必须放在 XML 配置文件中,否则容器就会抛出一个 BeanInitializationException 异常。

下面显示的是一个使用 @Required 注释的示例

下面是 Student.java 文件的内容:

1 package com.spring.chapter5;

2

3 import java.util.List;

4 import java.util.Set;

5

6 import org.springframework.beans.factory.annotation.Required;

7

8

9

10 public class Student {

11

12 public String getName() {

13 return name;

14 }

15 @Required

16 public void setName(String name) {

17 this.name = name;

18 }

19

20 public int getAge() {

21 return age;

22 }

23 @Required

24 public void setAge(int age) {

25 this.age = age;

26 }

27 private String name;

28 private int age;

29

30

31

32 }

下面是 MainApp.java 文件的内容:

1 package com.spring.chapter5;

2

3

4 import java.util.List;

5

6 import org.springframework.context.ApplicationContext;

7 import org.springframework.context.support.AbstractApplicationContext;

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

9

10 public class Main {

11 /**

12 * Spring @Required 注解注入

13 * author:

14 * mail:2536201485@qq.com

15 * 时间:

16 */

17

18 public static void main(String[] args) {

19 ApplicationContext applicationContext=new ClassPathXmlApplicationContext("spring_xml/spring.xml");

20 Student student=(Student)applicationContext.getBean("student");

21 System.out.println("名字是:"+student.getName());

22 System.out.println("年龄是:"+student.getAge());

23

24

25 }

26

27 }

下面是配置文件 Beans.xml: 文件的内容:  上面的头信息就省略了

    

<!-- @Required 注解 -->

<bean id="student" class="com.spring.chapter5.Student">

<property name="name" value="张三"></property>

<!-- age属性 -->

<!-- <property name="age" value="24"></property> -->

</bean>

@Required 注释应用于 bean 属性的 setter 方法,它表明受影响的 bean 属性在配置时必须放在 XML 配置文件中,否则容器就会抛出一个 BeanInitializationException 异常。下面显示的是一个使用 @Required 注释的示例,当中setAge()方法标注了当中age的属性配置被注销了。所以会报 BeanInitializationException 异常。在生产规模的应用程序中,IoC容器中可能会有数百或数千个bean,并且它们之间的依赖关系通常非常复杂。setter注入的一个缺点是你很难检查是否已经设置了所有必需的属性

运行结果:

名字是:张三

年龄是:24

注意:在使用@Required注解注入时,我们需要添加spring-aop的依赖包

本文内容总结:基于注解的配置,下面是 Student.java 文件的内容:,下面是 MainApp.java 文件的内容:,下面是配置文件 Beans.xml: 文件的内容:  上面的头信息就省略了,运行结果:,

原文链接:https://www.cnblogs.com/ysource/p/12781889.html

以上是 Spring基于注解@Required配置 的全部内容, 来源链接: utcz.com/z/296201.html

回到顶部