基于注解的配置
从 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的依赖包