Spring5 IOC容器管理—基于注解方式
IOC操作Bean管理(基于注解方式)
-
- 1. 注解
- 2. 注解关键词
- 3. 基于注解方式实现对象的创建
- 4. 开启组件扫描细节配置
- 5. 基于注解方式实现属性注入
- 6. 完全注解开发
1. 注解
(1)注解是代码特殊标记,格式:@注解名称(属性名称=属性值, 属性名称=属性值…)
(2)使用注解,注解可以作用在类上面,方法上面,属性上面
(3)使用注解目的:简化xml配置
2. 注解关键词
下面四个注解的功能是一样的,都可以用来创建 bean 实例
@Component@Service@Controller@Repository
3. 基于注解方式实现对象的创建
- 引入依赖 (引入spring-aop jar包)
- 开启组件扫描(XML文件中配置)
<context:component-scan base-package="com.spring"></context:component-scan>
- 创建类,在类上面添加创建对象注解
//在注解里面 value 属性值可以省略不写,//默认值是类名称,首字母小写//UserService -- userService@Component(value = "userService") //注解等同于XML配置文件:public class UserService {public void add() { System.out.println("service add.......");}}
以上三步就成功实现了bean对象的创建。
4. 开启组件扫描细节配置
<context:component-scan base-package="com.atguigu" use-default-filters="false"> <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/> </context:component-scan><context:component-scan base-package="com.atguigu"><context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/></context:component-scan>
5. 基于注解方式实现属性注入
- @Autowired:根据属性类型进行自动装配
第一步 把 service 和 dao 对象创建,在 service 和 dao 类添加创建对象注解
第二步 在 service 注入 dao 对象,在 service 类添加 dao 类型属性,在属性上面使用注解
//Dao实现类@Repository//@Repository(value = "userDaoImpl1")public class UserDaoImpl implements UserDao { @Override public void add() { System.out.println("dao add....."); }}@Servicepublic class UserService {//定义 dao 类型属性//不需要添加 set 方法//添加注入属性注解@Autowiredprivate UserDao userDao;public void add() {System.out.println("service add.......");userDao.add();}}
- @Qualifier:根据名称进行属性注入。此注解需要跟@Autowired 一起使用
//定义 dao 类型属性//不需要添加 set 方法//添加注入属性注解@Autowired //根据类型进行注入//根据名称进行注入(目的在于区别同一接口下有多个实现类,根据类型就无法选择,从而出错!)@Qualifier(value = "userDaoImpl1") private UserDao userDao;
- @Resource:可以根据类型注入,也可以根据名称注入。它属于javax包下的注解,不推荐使用
//@Resource //根据类型进行注入@Resource(name = "userDaoImpl1") //根据名称进行注入private UserDao userDao;
- @Value:注入普通类型属性
@Value(value = "Spring") //给name属性赋值private String name;
6. 完全注解开发
- 创建配置类SpringConfig,替代 xml 配置文件
@Configuration //作为配置类,替代 xml 配置文件@ComponentScan(basePackages = {"com.spring"})public class SpringConfig { }
<context:component-scan base-package="com.spring"></context:component-scan>
- 编写测试类
@Testpublic void testService() { //加载配置类ApplicationContext context= new AnnotationConfigApplicationContext(SpringConfig.class);UserService userService = context.getBean("userService", UserService.class);System.out.println(userService);userService.add();}
这种开发模式就省去了较为繁琐的xml文件配置。