IOC 操作 Bean 管理---基于注解方式
- 1、什么是注解
- 2、Spring 针对 Bean 管理中创建对象提供注解
- 3、基于注解方式实现对象创建
- 4、开启组件扫描细节配置
- 5、基于注解方式实现属性注入
- 1)@Autowired:根据属性类型进行自动装配
- 2)@Qualifier:根据名称进行注入
- 3)@Resource:可以根据类型注入,也可以根据名称注入
- 4)@Value:注入普通类型属性
- 6、完全注解开发
- 1)创建配置类,替代 xml 配置文件
- 2)编写测试类
1、什么是注解
(1)注解是代码特殊标记,格式:@注解名称(属性名称=属性值, 属性名称=属性值…)
(2)使用注解,注解作用在类上面、方法上面、属性上面
(3)使用注解目的:简化 xml 配置
2、Spring 针对 Bean 管理中创建对象提供注解
Spring提供四种可以创建bean实例的的注解。
@Component
@Service
@Service是一个特殊的@Component,它本质上是@Component的派生注解。一般用在service层,通过使用@Service,我们可以告诉Spring容器去自动扫描和注册这些类为Bean,供依赖注入使用。
@Controller
@Controller是一个特殊的@Component,它本质上是@Component的派生注解。一般用在Controller层,通过使用@Controller,我们可以告诉Spring容器去自动扫描和注册这些类为Bean,供依赖注入使用。
@Repository
@Repository是一个特殊的@Component,它本质上是@Component的派生注解。一般用在Dao层,通过使用@Repository,我们可以告诉Spring容器去自动扫描和注册这些类为Bean,供依赖注入使用。
3、基于注解方式实现对象创建
第一步 引入依赖 (引入spring-aop jar包)
第二步 开启组件扫描
<!--开启组件扫描1 如果扫描多个包,多个包使用逗号隔开2 扫描包上层目录
-->
<context:component-scan base-package="com.atguigu"></context:component-scan>
第三步 创建类,在类上面添加创建对象注解
//在注解里面 value 属性值可以省略不写,
//默认值是类名称,首字母小写
//UserService -- userService
@Component(value = "userService") //注解等同于XML配置文件:<bean id="userService" class=".."/>
public class UserService {public void add() {System.out.println("service add.......");}
}
4、开启组件扫描细节配置
<!--示例 1use-default-filters="false" 表示现在不使用默认 filter,自己配置 filtercontext:include-filter ,设置扫描哪些内容
-->
<context:component-scan base-package="com.atguigu" use-defaultfilters="false"><context:include-filter type="annotation"expression="org.springframework.stereotype.Controller"/><!--代表只扫描Controller注解的类-->
</context:component-scan>
<!--示例 2下面配置扫描包所有内容context:exclude-filter: 设置哪些内容不进行扫描
-->
<context:component-scan base-package="com.atguigu"><context:exclude-filter type="annotation"expression="org.springframework.stereotype.Controller"/><!--表示Controller注解的类之外一切都进行扫描-->
</context:component-scan>
5、基于注解方式实现属性注入
第一步 把 service 和 dao 对象创建,在 service 和 dao 类添加创建对象注解
第二步 在 service 注入 dao 对象,在 service 类添加 dao 类型属性,在属性上面使用注解
1)@Autowired:根据属性类型进行自动装配
@Service
public class UserService {//定义 dao 类型属性//不需要添加 set 方法//添加注入属性注解@Autowiredprivate UserDao userDao;public void add() {System.out.println("service add.......");userDao.add();}
}//Dao实现类
@Repository
//@Repository(value = "userDaoImpl1")
public class UserDaoImpl implements UserDao {@Overridepublic void add() {System.out.println("dao add.....");}
}
2)@Qualifier:根据名称进行注入
@Qualifier 注解的使用,必须和@Autowired 一起使用
@Service
public class UserService {
//定义 dao 类型属性
//不需要添加 set 方法
//添加注入属性注解@Autowired //根据类型进行注入//根据名称进行注入(目的在于区别同一接口下有多个实现类,根据类型就无法选择,从而出错!)@Qualifier(value = "userDaoImpl1") private UserDao userDao;public void add() {System.out.println("service add.......");userDao.add();}
}
3)@Resource:可以根据类型注入,也可以根据名称注入
@Resource属于javax包下的注解,不推荐使用!
@Service
public class UserService {
//定义 dao 类型属性
//不需要添加 set 方法
//添加注入属性注解//@Resource //根据类型进行注入,不必写明属性@Resource(name = "userDaoImpl1") //根据名称进行注入,需要在括号内写上name属性private UserDao userDao;public void add() {System.out.println("service add.......");userDao.add();}
}
4)@Value:注入普通类型属性
@Value(value = "abc")
private String name
6、完全注解开发
抛弃xml配置文件,使用配置类代替,完全基于注解。
1)创建配置类,替代 xml 配置文件
SpringConfig.java
@Configuration //作为配置类,替代 xml 配置文件
@ComponentScan(basePackages = {"com.atguigu"})
public class SpringConfig {
}
2)编写测试类
测试配置类是否生效。
@Test
public void testService2() {//加载配置类//ApplicationContext context =new ClassPathXmlApplicationContext("bean.xml",SpringConfig.class);ApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);UserService userService = context.getBean("userService",UserService.class);System.out.println(userService);userService.add();
}