002_Spring5-IOC容器-Bean管理-Annotation方式

什么是注解

1)注解是代码特殊标记,格式:@注解名称(属性名称=属性值,属性名称=属性值…)

2)使用注解,注解作用在类上面,方法上面,属性上面

3)使用注解目的:简化xml配置

Spring针对Bean管理中创建对象提供注解

1)@Compenent,组件

2)@Service,业务

3)@Controller,web层

4)@Repository,持久层

上面四个注解功能是一样的,都可以创建bean实例

基于注解方式实现对象创建

第一步,引入spring-aop依赖

第二步,引入context名称空间

1
2
xmlns:context="http://www.springframework.org/schema/context"
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd

第三步,开启组件扫描

1
2
3
4
5
<!--开启组件扫描
1 如果扫描多个包,多个包使用逗号隔开
2 扫描包上层目录
-->
<context:component-scan base-package="cn.ysliu.annotation" />
1
2
3
4
5
6
7
8
9
10
11
12
13
package cn.ysliu.annotation.service;

import org.springframework.stereotype.Service;

/**
* value = "userService"可以不写,默认类名首字母小写
*/
@Service(value = "userService")
public class UserService {
public void add() {
System.out.println("userService add....");
}
}

组件扫描配置

指定扫描的类型及内容:

1
2
3
4
5
6
7
<!--  use-default-filters="false": 不使用默认filter,
context: include-filter: 使用自定义filter
type="annotation": 只扫描注解
expression: 扫描哪些注解 -->
<context:component-scan base-package="cn.ysliu.annotation" use-default-filters="false">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Service"/>
</context:component-scan>

排除指定扫描的类型及内容:

1
2
3
4
<!-- 排除指定扫描的类型及内容 -->
<context:component-scan base-package="cn.ysliu.annotation">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service"/>
</context:component-scan>

基于注解方式实现属性注入

1)@Autowired:根据属性类型进行自动装配

第一步 把 service 和 dao 对象创建,在 service 和 dao 类添加创建对象注解

第二步 在 service 注入 dao 对象,在 service 类添加 dao 类型属性,在属性上面使用注解

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
/**
* value = "userService"可以不写,默认类名首字母小写
*/
@Service(value = "userService")
public class UserService {

// 定义dao类型属性
// 不需要添加set方法
// 添加注入属性注解
@Autowired
private UserDAO userDAO;

public void add() {
System.out.println("userService add....");
userDAO.add();
}

}

2)@Qualifier:根据名称进行注入,这个@Qualifier 注解的使用,和上面@Autowired 一起使用

1
2
3
4
5
6
7
// 定义dao类型属性
// 不需要添加set方法
// 添加注入属性注解
@Autowired
// 根据名称进行注入(目的是为了当接口有多个实现类时,根据名称进行注入)
@Qualifier("userDAOImpl1")
private UserDAO userDAO;

3)@Resource:可以根据类型注入,也可以根据名称注入(它属于javax包下的注解,不推荐使用!)

1
2
3
//@Resource //根据类型进行注入
@Resource(name = "userDAOImpl1") //根据名称进行注入
private UserDAO userDAO;

4)@Value:注入普通类型属性

1
2
@Value(value = "abc")
private String name

完全注解开发

1)创建配置类,替代 xml 配置文件

1
2
3
4
@Configuration //作为配置类,替代 xml 配置文件
@ComponentScan(basePackages = {"com.atguigu"})
public class SpringConfig {
}

2)编写测试类

1
2
3
4
5
6
7
@Test
public void testAnnotationWithFull() {
// 加载配置类
ApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);
UserService userService = context.getBean("userService", UserService.class);
userService.add();
}